av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

Django中url與path及re_path的區(qū)別說明

瀏覽:3日期:2024-09-12 08:43:30
Django中url與path及re_path區(qū)別

初學(xué)者一般不能分清兩者的區(qū)別,所這簡單介紹下兩者.首先,url是Django 1.x中的寫法,p在Django2.1中,開始舍棄django1.x中的url寫法。

在django2.x中,描寫url配置的有兩個(gè)函數(shù)path和re_path.re_path()函數(shù)可以看做是django 1.x中得url函數(shù),即可以在路徑中使用正則.

一.path和url的區(qū)別:

django.urls pathdjango.conf.urls url

path與url是兩個(gè)不同的模塊,效果都是響應(yīng)返回頁面, path調(diào)用的是python第三方模塊或框架,而url則是自定義的模塊,如Views下的def函數(shù)對應(yīng)你url中的參數(shù)值.

例如:

url(r’^login’,views.login), def login(request): return render(request,’login.html’)1、url

在settings.py文件中有一個(gè)ROOT_URLCONF設(shè)置,設(shè)置的是在訪問網(wǎng)址時(shí)通過哪一個(gè)url文件去匹配所請求的網(wǎng)址

url參數(shù)

url或者re_path要復(fù)雜一些 (r’^blog/(?P[0-9]{4})/′)首先需要開始符和結(jié)尾符 ’) 首先需要開始符^和結(jié)尾符 ′)首先需要開始符和結(jié)尾符,參數(shù)匹配一個(gè) ()就是一個(gè)匹配參數(shù),

(?P<匹配的字段名>正則表達(dá)式)

進(jìn)行匹配是不包括get或者post請求方式的參數(shù)及域名比如www.qq.com/blog?num=1并不會(huì)匹配?后邊的字符

可以給request參數(shù)設(shè)置一個(gè)默認(rèn)值,最常見的分頁url,比如

urlpatterns=[ url(r’^page/$’,views.page), url(r’^page(?P<num>[0-9]+)$’,views.page) ] #views def page(request,num=’1’): pass

自定義錯(cuò)誤頁面關(guān)鍵字handler400=blog.views.page_no_find

#urls.py … handler400=blog.views.page_no_find2、path

參數(shù)的使用方法path(‘blog/str:string/’) 簡單了很多,就是尖括號,前邊是str代表參數(shù)的類型,后面代表參數(shù)的名稱

path參數(shù)類型

捕獲url中的參數(shù)需要用到尖括號<> 指定尖括號中的值類型比如int:astr:link這個(gè)轉(zhuǎn)換器還有許多類型比如:

int 匹配0和正整數(shù)

str 匹配任何空字符串但不包括/

slug 可理解為注釋 匹配任何ascii碼包括連接線和下劃線

uuid 匹配一個(gè)uuid對象(該對象必須包括破折號—,所有字母必須小寫)

path 匹配所有的字符串 包括/(意思就是path前邊和后邊的所有)

3.re_path

如果遇上路徑和轉(zhuǎn)換器語法都不足以定義的URL模式,那么就需要使用正則表達(dá)式,這時(shí)候就需要使用re_path(),而非path()。

舉例:傳遞 數(shù)字結(jié)尾的參數(shù)

re_path(r’(d+)/$’,views.peopleList,name=’peopleList’),二、python3中使用django2,常見設(shè)置path問題1.Django2中使用

在python3中使用django2的時(shí)候,在設(shè)置urls的時(shí)候,會(huì)遇到一些坑。這里做一下記錄。

系統(tǒng)的urls.py里,在1.X的時(shí)候,都是采用的url方式。如下

url(r’^’, include('test1.urls')),

在2.0中,它推薦使用的是path模塊,所以這里就改寫一下。引包

from django.urls import path path(’’, include('test1.urls')),

注意:

如果要使用正則,則要引入re_path,from django.urls import path, re_path

這里面的正則寫法,有點(diǎn)意思,一定要使用()把正則包起來,然后用?P正式表達(dá)式 這種形式來表式

2.APP中使用path

1.x里面的寫法是

url(r’^page=(d+)&key=(w+)$’, views.detail, name=”detail”),

現(xiàn)在的寫法

re_path(’page=(?P<page>d+)&key=(?P<key>w+)’, views.detail, name='detail'),

這樣一對比就能明白了吧,使用的鏈接是http://127.0.0.1:8000/page=12&key=abc

3.系統(tǒng)的urls.py里的namespace的問題

1.x中寫法

url(r’^’, include('test1.urls', namespace=’test1’)),

可是在2.0中你這么寫,會(huì)報(bào)錯(cuò),說什么app_name的,這個(gè)自己可以看一下,怎么解決呢,其實(shí)很簡單,只要在自己項(xiàng)目urls.py中加上這句就行了.如果不加的話可能報(bào)錯(cuò),

app_name = ’test1’(你的APP名)

注:

使用url也是可以的,為了簡便起見,盡量使用符合版本的字段,另外在寫路徑時(shí)應(yīng)該嚴(yán)格按照語法,比如’^’ 和/$就不能缺,不能前面寫url,括號里面確按照path的寫法,這樣很容易出錯(cuò),到了關(guān)鍵時(shí)刻,很難定位問題點(diǎn),很浪費(fèi)時(shí)間.

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 日韩欧美精品一区 | 欧美性大战久久久久久久蜜臀 | 亚洲精品久久久久久久久久久 | 一区二区精品在线 | 中文成人无字幕乱码精品 | 久久国产精品视频 | 一级大片免费 | 国产99热在线 | 日韩一二区 | 日韩视频免费看 | 日韩福利片| 日韩一及片 | 成在线人视频免费视频 | 国产福利在线播放 | 桃花av在线| 91精品国产高清久久久久久久久 | 美女黄18岁以下禁止观看 | 日韩精品专区在线影院重磅 | 一呦二呦三呦国产精品 | 欧美jizzhd精品欧美巨大免费 | 免费成年网站 | 欧美在线资源 | 久久91av| 国产精品毛片av一区 | 亚洲国产高清高潮精品美女 | 91精品国产综合久久精品 | 成人在线免费观看 | 天天干天天爱天天 | 日日夜夜精品免费视频 | 视频一区二区国产 | 97视频精品| 亚洲国产精品久久久久秋霞不卡 | 国产探花在线精品一区二区 | 久久噜噜噜精品国产亚洲综合 | 91久久精品视频 | jvid精品资源在线观看 | 免费成人av | 国产美女特级嫩嫩嫩bbb片 | 天天插日日操 | 精品日韩一区二区三区av动图 | 精品国产三级 |