久久久久久AV无码免费看大片,亚洲一区精品人人爽人人躁,国产成人片无码免费爱线观看,亚洲AV成人无码精品网站,为什么晚上搞的时候要盖被子

Django之無(wú)名分組,有名分組

時(shí)間:2022-01-20 21:33:00 類(lèi)型:python
字號(hào):    

  在Django 2.0版本之前,在urls,py文件中,用url設(shè)定視圖函數(shù)

urlpatterns = [
  url(r'login/',views.login),
]

  其中第一個(gè)參數(shù)是正則匹配,如下代碼,輸入http://127.0.0.1:8000/login,出現(xiàn)的是login頁(yè)面,但是輸入login2,出現(xiàn)的還是login頁(yè)面,這是因?yàn)镈jango會(huì)將匹配成功的返回,不會(huì)繼續(xù)往下匹配

urlpatterns = [
  url(r'login',views.login),
  url(r'login2',views.login2),
]

  所以為了避免上面這種情況,可以在第一個(gè)參數(shù)加上正則表達(dá)式

urlpatterns = [
  url(r'^login/$',views.login),
  url(r'^login2/$',views.login2),
]

  ^號(hào)限定開(kāi)頭,

      $限定結(jié)尾,' / '為匹配機(jī)制,

           比如第一次輸入:http://127.0.0.1:8000/login,沒(méi)有匹配成功,系統(tǒng)會(huì)自動(dòng)加上‘/‘再進(jìn)行一次匹配

  這樣就可以寫(xiě)出首頁(yè)和尾頁(yè)(尾頁(yè)是指找不到對(duì)應(yīng)頁(yè)面時(shí)打開(kāi)的頁(yè)面,俗稱(chēng)404)

  

urlpatterns = [
  url(r'^$',views.home), #這是首頁(yè)
  url(r'',views.error) #這是尾頁(yè)]

  同樣的既然可以進(jìn)行正則匹配,那么就可以寫(xiě)更多的正則語(yǔ)法:

urlpatterns = [
  url(r'^login/[0-9]{4}$',views.login),
]

  類(lèi)似上面寫(xiě)出的正則,就是login/ 后面隨意加上4位數(shù)字都可以訪問(wèn)login頁(yè)面

  同樣的正則還有分組的概念,但是在Django中把分組分為兩種:無(wú)名分組和有名分組

  無(wú)名分組

urlpatterns = [
  url(r'^login/([0-9]{4})$',views.login),
]

  在普通的正則匹配中加上()就是無(wú)名分組,那么這樣有什么意義呢?

  首先在后端的views上,會(huì)得到一個(gè)分組的參數(shù),以上面代碼為例,那么views.login函數(shù)的參數(shù)除了request,還需要添加一個(gè)參數(shù)(名字隨意),進(jìn)行幾次分組那么就需要多添加幾次參數(shù)

  進(jìn)入view頁(yè)面,其中xxx的名字是隨意的,傳進(jìn)來(lái)的分組的數(shù)據(jù)例如我輸入的網(wǎng)址是:login/222,那么xxx的值為222

  

def login(request,xxx):    print(xxx)

  有名分組:

  有名分組其實(shí)就是在無(wú)名的分組的基礎(chǔ)上加上了名字

urlpatterns = [
  url(r'^login/(?P<year>[0-9]{4})$',views.login),
]

  語(yǔ)法為:(?P<名字> 正則表達(dá)式),就是在無(wú)名分組的括號(hào)里面加上了?P<名字>,注意其中P為大寫(xiě)

  既然有了名字,那么在views頁(yè)面就不能給函數(shù)傳遞隨意的參數(shù)了:

def login(request,year):    print(year)

  第二個(gè)參數(shù)year是urls頁(yè)面命名的名字:

如果名字不一樣則會(huì)報(bào)錯(cuò)

  這里有一個(gè)坑,既然分組有有名分組和無(wú)名分組,那么能不能一起使用?

答:不行,別問(wèn),問(wèn)就是不行

<