在Django 2.0版本之前,在urls,py文件中,用url設(shè)定視圖函數(shù)
urlpatterns = [ url(r'login/',views.login), ]
其中第一個參數(shù)是正則匹配,如下代碼,輸入http://127.0.0.1:8000/login,出現(xiàn)的是login頁面,但是輸入login2,出現(xiàn)的還是login頁面,這是因為Django會將匹配成功的返回,不會繼續(xù)往下匹配
urlpatterns = [ url(r'login',views.login), url(r'login2',views.login2), ]
所以為了避免上面這種情況,可以在第一個參數(shù)加上正則表達(dá)式
urlpatterns = [ url(r'^login/$',views.login), url(r'^login2/$',views.login2), ]
^號限定開頭,
$限定結(jié)尾,' / '為匹配機(jī)制,
比如第一次輸入:http://127.0.0.1:8000/login,沒有匹配成功,系統(tǒng)會自動加上‘/‘再進(jìn)行一次匹配
這樣就可以寫出首頁和尾頁(尾頁是指找不到對應(yīng)頁面時打開的頁面,俗稱404)
urlpatterns = [ url(r'^$',views.home), #這是首頁 url(r'',views.error) #這是尾頁]
同樣的既然可以進(jìn)行正則匹配,那么就可以寫更多的正則語法:
urlpatterns = [ url(r'^login/[0-9]{4}$',views.login), ]
類似上面寫出的正則,就是login/ 后面隨意加上4位數(shù)字都可以訪問login頁面
同樣的正則還有分組的概念,但是在Django中把分組分為兩種:無名分組和有名分組
無名分組:
urlpatterns = [ url(r'^login/([0-9]{4})$',views.login), ]
在普通的正則匹配中加上()就是無名分組,那么這樣有什么意義呢?
首先在后端的views上,會得到一個分組的參數(shù),以上面代碼為例,那么views.login函數(shù)的參數(shù)除了request,還需要添加一個參數(shù)(名字隨意),進(jìn)行幾次分組那么就需要多添加幾次參數(shù)
進(jìn)入view頁面,其中xxx的名字是隨意的,傳進(jìn)來的分組的數(shù)據(jù)例如我輸入的網(wǎng)址是:login/222,那么xxx的值為222
def login(request,xxx): print(xxx)
有名分組:
有名分組其實(shí)就是在無名的分組的基礎(chǔ)上加上了名字
urlpatterns = [ url(r'^login/(?P<year>[0-9]{4})$',views.login), ]
語法為:(?P<名字> 正則表達(dá)式),就是在無名分組的括號里面加上了?P<名字>,注意其中P為大寫
既然有了名字,那么在views頁面就不能給函數(shù)傳遞隨意的參數(shù)了:
def login(request,year): print(year)
第二個參數(shù)year是urls頁面命名的名字:
如果名字不一樣則會報錯
這里有一個坑,既然分組有有名分組和無名分組,那么能不能一起使用?
答:不行,別問,問就是不行