簡單來說,就是通過路由層中的path函數(shù),告訴django遇到那個url,執(zhí)行那個視圖函數(shù)
創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比中江網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式中江網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋中江地區(qū)。費用合理售后完善,十余年實體公司更值得信賴。
1.客戶在瀏覽器輸入網(wǎng)址→請求進入django的setting.py中的ROOT_URLCONF尋找指定使用的urls.py文件位置(如果中間件有路由功能,urls文件功能會被其替代)
2.Django會先匹配項目目錄下的path路徑然后在匹配應用里面的url路徑,從上至下查找url匹配,一旦匹配成功,停止查找。
3.一旦匹配url成功后,路由層向視圖層傳遞下列參數(shù):
1)一個HttpRequest實例,即request
2)如果url中的可變參數(shù)沒有命名,那么就按照位置來與視圖函數(shù)中的形參一一對應,如果有則按關(guān)鍵字方式傳參
4.如果匹配不到url,Django會發(fā)出異常
re_path(r'^test/$',views.test)
注意:path路徑匹配是會自動在url后面加上一個斜杠,即先匹配test沒有找到,會自動加個/在匹配一次!
如何取消自動加斜杠?
在setting.py里添加APPEND_SLASH = False 默認是True
分組:就是給某一段正則表達式用小括號擴起來
無名分組:就是將括號內(nèi)的正則表達式匹配到的內(nèi)容當做位置參數(shù)傳遞給后面的視圖函數(shù)
from django.urls import path, re_path
re_path(r'^test/(\d+)/',views.test)
def test(request,xx): # xx這個參數(shù)就是對應path里面的(\d+)
pass
# 補充:path里面views.xxx,后面也可以在加一個參數(shù)(字典形式),該參數(shù)可以被傳到視圖函數(shù),視圖函數(shù)request后面在加個參數(shù)(字典的key)
有名分組:可以給正則表達式起個別名
from django.urls import path, re_path
re_path(r‘^(?P<自定義參數(shù)名>正則表達式)/$',view.xxx),
def test(request,自定義參數(shù)名):
pass
有名無名不能混用!單個分組可以使用多次!
反向解析的步驟:
# 1.先給改url起一個別名
re_path(r'^test/$',views.test,name='ooo')
# 2.后端反向解析(視圖層)
先導入reverse
from django.shortcuts import reverse
print(reverse(‘ooo’)) # 得到的就是對應別名的url
# 3.前端反向解析
在需要url的地方,改成如下格式:
111
1.無名分組
后端部分:
先導入reverse
from django.shortcuts import reverse
print(reverse(‘ooo’),args=(1,))#需要傳一個對應參數(shù)args,里面的1可以讓正則表達式匹配到
前端部分:
111
# 123是匹配到url的正則表達式
2.有名分組
其實是和無名分組一樣的,但是也可以寫成關(guān)鍵字方式傳參
print(reverse(‘ooo’),kwargs={‘year’:1111}))
傳入的數(shù)字參數(shù)一般是數(shù)據(jù)的主鍵值??!
起因:分布式路由是基于django應用誕生的,有了應用則就應該有分布式路由,主路由不用在處理用戶具體路由了,而是轉(zhuǎn)而做請求的分發(fā),具體的請求由各自的應用負責。
主路由語法:
from django.urls import path,include
# 匹配http://127.0.0.1:8000/music/index--music應用path('music/', include('music.urls'))
include('app名字.url模塊名')
作用是將當前path里面music路由轉(zhuǎn)到include里面的這個應用路由里處理
子路由語法:
手動創(chuàng)建一個urls.py,結(jié)構(gòu)和主路由完全一樣
只是path后面的第一個參數(shù),只需管主路由path匹配的后面一部分
在各路由起別名的時候,由于我們采用的是分布式路由開發(fā),很有可能每個開發(fā)人員起的別名是一樣的,這樣我們在進行反向解析的時候就沒有用了!
因此,名稱空間的使用很好的解決了這一問題!具體的語法如下:
# 總路由
re_path(r'^app01/',include('app01.urls',namespace='app01')),
re_path(r'^app02/',include('app02.urls',namespace='app02'))
# 解析的時候
# app01
urlpatterns = [
url(r'^reg/',views.reg,name='reg')
]
# app02
urlpatterns = [
url(r'^reg/',views.reg,name='reg')
]
# 視圖層:
reverse('app01:reg')
reverse('app02:reg')
# 模板層:
{% url 'app01:reg' %}
{% url 'app02:reg' %}
但其實,我們在起別名的時候只要保證別名不沖突,就沒有必要使用名稱空間。
一般情況下,有多個app的時候我們在起別名的時候會加上app的前綴,如name=‘a(chǎn)pp01_xxx’,這樣就能解決了!
path('page/', views.test),
說明:1.path轉(zhuǎn)換器:可以用來批量匹配一百個網(wǎng)頁分別為page/1、page/2...等
2.語法為:<轉(zhuǎn)換器類型:自定義名>
3.作用:若轉(zhuǎn)換器類型匹配到對應類型的數(shù)據(jù),則將數(shù)據(jù)按照關(guān)鍵字傳參的方式傳遞給視圖函數(shù)
4.轉(zhuǎn)換器的類型:str:匹配除了'/'之外的非空字符串;int:匹配0或者任何正整數(shù);# slug:匹配任意由ascll字母或數(shù)字以及連字符和下劃線組成的短標簽;path:匹配非空字段。