url映射的作用
根據Django的MTV模式,url的映射是根據用戶輸入或傳送而來的url路徑,來進行區分去執行相應的view函數來響應用戶的操作。
url映射的方式
Django項目的創建后,會自動創建和你項目名稱相同的全局文件包,urls.py就在其中。
urlpatterns = [
path('admin/', admin.site.urls),
]
這是Django自動添加的一條映射。我們的view函數在自己創建的app中,所以需要先引入app文件包中的views
from blog import views
這樣就可以在urlpatterns中添加自己的映射條件,例如
from blog import views
urlpatterns = [
path('admin/', admin.site.urls),
path('blog/',views.blog)
]
寫相應的視圖函數
from django.shortcuts import render,HttpResponse
def blog(request):
return HttpResponse("WELCOME")
這樣在瀏覽器中輸入127.0.0.1:8000/blog/就能看到返回的WELCOME了。
url映射的函數
urlpatterns中可以使用兩種函數,path()用來字符串路由,re_path()處理正則式路由。
path函數
必須有的參數
path()中有兩個必須填的參數,一個是路徑字符串,一個是所調用的函數。
就如上邊的例子
path('blog/',views.blog)
這個只匹配在你的路徑后加上blog/的情況,然后執行views下的blog函數,表示靜態,精確的映射。
路徑字符串除了填精確的路徑外,還可以填<類型:變量名>,可以在匹配 url的同時傳遞參數,而且匹配的范圍更加龐大。例如:
path('<int:year>/year/',views.year)
可以匹配”任意整型數字/year/“,並且匹配到的整型數字還會以變量名為year的形式作為參數傳遞給views.year函數。這里注意:views.year函數的參數名必須和你在url映射時起的名字相同,即“year”。
這里的數據類型還有其他幾種:
數據類型 | 說明 |
---|---|
str | 匹配除分隔符(/)外的非空字符 |
int | 匹配0和正整數 |
slug | 匹配字母、數字、橫杠、下划線組成的字符串,str的子集 |
uuid | 匹配格式化的UUID,如075194d3-6885-417e-a8a8-6c931e272f00 |
path | 匹配任何非空字符串,包括路徑分隔符,是全集 |
非必要參數
path中的非必要參數也有兩個,一個是用來給視圖函數傳遞的參數,一個是別名。
用來給視圖函數傳遞的參數除了上述直接在url中,還可以手動指定填入path()中,以字典的形式填入,因為這里的參數類型為**kwargs。而視圖函數中的參數同樣必須和字典中的鍵名相同。例如:
path('<int:year>/year/',views.year,{"name":"sfencs","age":20})
def year(req,year,name,age):
str1=str(year)+" "+name+" "+str(age)
return HttpResponse(str1)
如果url參數和字典類型參數都使用了,並且名稱相同,如:
path('<int:year>/year/',views.year,{"name":"sfencs","year":20})
那么在視圖函數中只能添加一個year參數,並且在字典中的year的數據20會覆蓋掉url中的數據。
最后一個參數是別名,例如:
path('blog/',views.blog,name="abc")
在html中,form表單提交的路徑就可以使用abc來代替/blog/,具體方式為
<form action="{% url 'alias' %}" method="post">
這種方式只允許在前端中使用,在地址欄中通過使用別名的方式訪問是不起作用的。
re_path()函數
re_path()函數和path()函數類似,但它是使用正則表達式的模式來代替字符串模式進行匹配,只要符合正則式的模式就可以匹配成功。
re_path("^\d+/day/",views.day)
這里也可以通過url來傳遞參數,使用的是正則式分組的方式
re_path("^(\d+)/day/",views.day)
沒有給分組起名字的模式,即為無命名參數,分組所匹配的數據會自動當參數傳遞給視圖函數,但是視圖函數的形參必須要多寫一個參數,名字任意。
re_path("^(?P<day>\d+)/day/",views.day)
上面這種為命名參數,視圖函數必須以其名字作為參數名,同樣,如果手動添加的參數與其名稱相同,那么手動添加的參數數據會將正則式中的覆蓋。
路由分發
假如我們一個項目中有多個app,那么所有的映射都寫到同一個urls.py,或者公用一個url,難免會產生錯誤,產生混淆,那么我們可以在每個app下建立自己的urls.py來處理自己的映射關系,在全局urls下進行分發。具體方式為:
在全局urls中添加
path('blog/',include('blog.urls'))
在blog文件夾下創建urls.py文件,在文件中寫入
from django.urls import path,re_path
from blog import views
urlpatterns = [
path("login/",views.login)
]
那么在地址欄中輸入/blog/login,就會先由全局urls分發到blog下的urls,再進行相應的視圖函數映射。
- 最后有一點要注意,所有的url映射都是從上到下按順序匹配,遇到第一個匹配成功后就不在往下進行了。