django中path和url函數(shù)的具體使用
在django學(xué)習(xí)中,經(jīng)??吹竭@兩種路由形式
from django.urls import path from django.conf.urls import url
django.urls 中的 path() 和 django.conf.urls 中的 url() 都是 Django 中用于 URL 路由的函數(shù),它們的作用是定義 URL 和視圖函數(shù)之間的映射關(guān)系,即當(dāng)用戶訪問某個(gè) URL 時(shí),Django 如何將請(qǐng)求發(fā)送給對(duì)應(yīng)的視圖函數(shù)來處理。
兩者的區(qū)別如下:
path() 函數(shù)是 Django 2.0 版本引入的新函數(shù),它更加直觀和易用,支持使用 str 類型的路由,可以通過 、、、 等轉(zhuǎn)換器來定義動(dòng)態(tài)參數(shù),而且不再需要使用正則表達(dá)式來匹配 URL,大大簡(jiǎn)化了 URL 配置的過程。例如:
from django.urls import path
from . import views
urlpatterns = [
? ? path('', views.index, name='index'),
? ? path('about/', views.about, name='about'),
? ? path('article/<int:id>/', views.article_detail, name='article_detail'),
]url() 函數(shù)是 Django 1.x 版本中用于 URL 配置的函數(shù),它的語法和 path() 不同,需要使用正則表達(dá)式來匹配 URL,使用起來相對(duì)復(fù)雜一些。例如:
from django.conf.urls import url from . import views urlpatterns = [ ? ? url(r'^$', views.index, name='index'), ? ? url(r'^about/$', views.about, name='about'), ? ? url(r'^article/(?P<id>\d+)/$', views.article_detail, name='article_detail'), ]
需要注意的是,在 Django 3.1 版本以后,url() 函數(shù)已經(jīng)被標(biāo)記為過時(shí),建議使用 path() 函數(shù)來進(jìn)行 URL 配置。因此,如果使用較新版本的 Django,應(yīng)該盡量使用 path() 函數(shù)來定義 URL 路由。
看下path()函數(shù)用法:
在 Django 中,path() 函數(shù)是用來定義 URL 路由的。它的語法如下:
path(route, view, kwargs=None, name=None)
其中:
- route:是一個(gè)字符串,用來匹配 URL,可以包含變量,例如:'articles/<int:pk>/'。當(dāng)有請(qǐng)求發(fā)生時(shí),Django 會(huì)嘗試將該字符串與請(qǐng)求的 URL 進(jìn)行匹配,如果匹配成功,就會(huì)調(diào)用對(duì)應(yīng)的 view 函數(shù)處理該請(qǐng)求。
- view:是一個(gè)視圖函數(shù)或者一個(gè)類視圖,用來處理匹配成功的請(qǐng)求,并返回一個(gè)響應(yīng)對(duì)象。
- kwargs:是一個(gè)可選的字典,包含額外的關(guān)鍵字參數(shù),傳遞給視圖函數(shù)。
- name:是一個(gè)可選的字符串,用來給 URL 路由起一個(gè)名稱,方便在模板中使用。
path() 函數(shù)支持的 URL 模式有以下幾種:
- 靜態(tài) URL 模式,例如 ‘articles/’。
- 帶參數(shù)的 URL 模式,例如 'articles/<int:pk>/',其中 <int:pk> 表示一個(gè)整數(shù)類型的參數(shù)。
- 帶參數(shù)的 URL 模式,例如 'articles/<slug:slug>/',其中 <slug:slug> 表示一個(gè)字符串類型的參數(shù),但是只能包含 ASCII 字符、數(shù)字、下劃線或連字符。
- 帶可選參數(shù)的 URL 模式,例如 'articles/<int:pk>/<str:slug>/',其中 <str:slug> 表示一個(gè)可選的字符串類型的參數(shù)。
- 匹配任意字符的 URL 模式,例如 'articles/<path:path>/',其中 <path:path> 可以匹配包含 / 符號(hào)的任意字符串。
在定義 URL 路由時(shí),可以使用多個(gè) path() 函數(shù)來定義不同的路由,并將它們作為列表傳遞給 urlpatterns 變量。例如:
from django.urls import path
from . import views
urlpatterns = [
? ? path('articles/', views.article_list),
? ? path('articles/<int:pk>/', views.article_detail),
]上面的代碼中,定義了兩個(gè) URL 路由,分別對(duì)應(yīng) /articles/ 和 /articles/int:pk/ 兩個(gè) URL。其中,views.article_list 和 views.article_detail 分別是處理請(qǐng)求的視圖函數(shù)。
Django2. 0中可以使用 re_path() 方法來兼容 1.x 版本中的 url() 方法,一些正則表達(dá)式的規(guī)則也可以通過 re_path() 來實(shí)現(xiàn)
到此這篇關(guān)于django中path和url函數(shù)的具體使用的文章就介紹到這了,更多相關(guān)django path和url內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mac PyCharm中的.gitignore 安裝設(shè)置教程
這篇文章主要介紹了Mac PyCharm中的.gitignore 安裝設(shè)置教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04
python獲取beautifulphoto隨機(jī)某圖片代碼實(shí)例
python獲取beautifulphoto隨機(jī)某圖片代碼實(shí)例,大家參考使用吧2013-12-12
pytorch 數(shù)據(jù)處理:定義自己的數(shù)據(jù)集合實(shí)例
今天小編就為大家分享一篇pytorch 數(shù)據(jù)處理:定義自己的數(shù)據(jù)集合實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12
基于Python實(shí)現(xiàn)自動(dòng)用小寫字母替換文件后綴的大寫字母
本文介紹基于Python語言,基于一個(gè)大文件夾,遍歷其中的多個(gè)子文件夾,對(duì)于每一個(gè)子文件夾中的大量文件,批量將其文件的名稱或后綴名中的字母由大寫修改為小寫的方法,文中有相關(guān)的代碼示例供大家參考,需要的朋友可以參考下2024-04-04
Python驗(yàn)證用戶密碼是否規(guī)范腳本示例
對(duì)用戶密碼的強(qiáng)度進(jìn)行校驗(yàn),要求用戶密碼達(dá)到一定的強(qiáng)度,符合安全性要求,這篇文章主要給大家介紹了關(guān)于Python驗(yàn)證用戶密碼是否規(guī)范的相關(guān)資料,需要的朋友可以參考下2024-05-05
python傳到前端的數(shù)據(jù),雙引號(hào)被轉(zhuǎn)義的問題
這篇文章主要介紹了python傳到前端的數(shù)據(jù),雙引號(hào)被轉(zhuǎn)義的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-04-04
Python3非對(duì)稱加密算法RSA實(shí)例詳解
這篇文章主要介紹了Python3非對(duì)稱加密算法RSA,結(jié)合實(shí)例形式分析了Python3 RSA加密相關(guān)模塊安裝及使用操作技巧,需要的朋友可以參考下2018-12-12
tkinter如何實(shí)現(xiàn)label超鏈接調(diào)用瀏覽器打開網(wǎng)址
這篇文章主要介紹了tkinter如何實(shí)現(xiàn)label超鏈接調(diào)用瀏覽器打開網(wǎng)址問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01

