Django測試開發-7-二級路由詳解


from django.contrib import admin
from django.urls import path, re_path
from django.conf.urls import url,include

from my_app.urls import app_name
from . import view
from my_app import views

urlpatterns = [

    path('admin/', admin.site.urls),
    url(r'^admin/', admin.site.urls),
    url(r'^my_app/',include('my_app.urls', namespace='my_app')),
    url(r'^$',view.index),
    path('hello/',view.hello),
    # 添加這一句,my_app/代表跳轉到my_app APP中,views.index是關聯對應views.py中的一個函數
    url(r'^my_app/',views.index),
    url(r'^my_app/', include(('my_app.urls',app_name), namespace="my_app")),
    path('vote/',include("vote.urls"))
    re_path('^index/$',view.index,name='index'),

]

一、include用法:

其中

urlpatterns = [

    # url(r'^my_app/',include('my_app.urls', namespace='my_app')),
    url(r'^my_app/', include(('my_app.urls',app_name), namespace="my_app")),
    path('vote/',include("vote.urls"))
]

include語法相當於多級路由,它把接收到的url地址去除與此項匹配的部分,將剩下的字符串傳遞給下一級路由urlconf進行判斷

項目根路由不關心具體app的路由策略,只管往指定的二級路由轉發,實現了應用解耦。app所屬的二級路由可以根據自己的需要隨意編寫,不會和其它的app路由發生沖突。app目錄可以放置在任何位置,而不用修改路由.

 

二、path用法:

path('admin/', admin.site.urls),
path('vote/',include("vote.urls"))

源碼如下:

def _path(route, view, kwargs=None, name=None, Pattern=None):
    if isinstance(view, (list, tuple)):
        # For include(...) processing.
        pattern = Pattern(route, is_endpoint=False)
        urlconf_module, app_name, namespace = view
        return URLResolver(
            pattern,
            urlconf_module,
            kwargs,
            app_name=app_name,
            namespace=namespace,
        )
    elif callable(view):
        pattern = Pattern(route, name=name, is_endpoint=True)
        return URLPattern(pattern, view, kwargs, name)
    else:
        raise TypeError('view must be a callable or a list/tuple in the case of include().')


path = partial(_path, Pattern=RoutePattern)

路由系統中最重要的path()方法可以接收4個參數,其中2個是必須的:routeview,以及2個可選的參數:kwargsname

參數詳解:

route:
'''
參數詳解:

route 是一個匹配 URL 的准則(類似正則表達式)。當 Django 響應一個請求時,它會從 urlpatterns 的第一項開始,
按順序依次匹配列表中的項,直到找到匹配的項,然后執行該條目映射的視圖函數或下級路由,其后的條目將不再繼續匹配。
因此,url路由的編寫順序非常重要!

着重注意的是,route不會匹配 GET 和 POST 參數或域名。
例如,URLconf 在處理請求 https://127.0.0.1:8000/my_app/時,它會嘗試匹配 my_app/。
處理請求 https://127.0.0.1:8000/my_app/?page=3 時,也只會嘗試匹配 my_app/。
'''

view:

'''
view指的是處理當前url請求的視圖函數。當Django匹配到某個路由條目時,自動將封裝的HttpRequest對象作為第一個參數,
被“捕獲”的參數以關鍵字參數的形式,傳遞給該條目指定的視圖view。
'''
kwargs和name
kwargs:

任意數量的關鍵字參數可以作為一個字典傳遞給目標視圖。

name:

對你的URL進行命名,讓你能夠在Django的任意處,尤其是模板內顯式地引用它。這是一個非常強大的功能,相當於給URL取了個全局變量名,不會將url匹配地址寫死

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM