Django模板標簽中url使用詳解(url跳轉(zhuǎn)到指定頁面)
django {% url %} 模板標簽使用
inclusions/_archives.html
...{% for date in date_list %}<li><a href='http://www.hdgsjgj.cn/bcjs/{% url ’blog:archive’ date.year date.month %}' rel='external nofollow' >{{ date.year }} 年 {{ date.month }} 月</a></li>{% endfor %}...
這里 {% url %} 這個模板標簽的作用是解析視圖函數(shù) blog:archive 對應(yīng)的 URL 模式,并把 URL 模式中的年和月替換成 date.year,date.month 的值。
{% url %} 模板標簽接收的第一個參數(shù)為被解析視圖函數(shù)的端點值,這個端點值由 2 部分組成,中間由冒號分隔。第一部分為在應(yīng)用的 urls.py 中指定的 app_name 的值(充當命名空間,這樣即使不同 app 下有相同的視圖函數(shù)名,也不會沖突),第二部分 path 函數(shù)中傳入的 name 參數(shù)的值。比如在 blog 應(yīng)用的 urls.py 模塊,我們指定了 app_name = ’blog’,archive 視圖函數(shù)的 url 模式為 path(’archives/<int:year>/<int:month>/’, views.archive, name=’archive’),因此對應(yīng)的端點值為 blog:archive。
{% url %} 模板標簽接收的其它參數(shù)為 URL 路徑參數(shù),即 URL 模式中路徑參數(shù)轉(zhuǎn)換器需要捕獲的值。例如 archive 視圖函數(shù)對應(yīng)的 URL 模式為 archives/<int:year>/<int:month>/,假設(shè) date.year=2017,date.month=5,那么 {% url ’blog:archive’ date.year date.month %} 模板標簽返回的值為 /archives/2017/5/。
為什么要使用 {% url %} 模板標簽?zāi)??事實上,我們把超鏈接?href 屬性設(shè)置為 /archives/{{ date.year }}/{{ date.month }}/ 同樣可以達到目的,但是這種寫法是硬編碼的。雖然現(xiàn)在 blog:archive 視圖函數(shù)對應(yīng)的 URL 模式是這種形式,但是如果哪天這個模式改變了呢?如果使用了硬編碼的寫法,那你需要把每一處 /archives/{{ date.year }}/{{ date.month }}/ 修改為新的模式。但如果使用了 {% url %} 模板標簽,則不用做任何修改。
示例
1、主urls.py文件配置如下:
from django.urls import pathfrom django.conf.urls import include from myblog import viewsurlpatterns = [ path(’’, views.index), path(’myblog/’, include(’myblog.urls’)),]
2、APP的urls.py文件配置如下:
from django.urls import pathfrom myblog import views urlpatterns = [ path(’’, views.index), path(’login/’, views.login, name=’login’), # 這里設(shè)置name,為了在模板文件中,寫name,就能找到這個路由 path(’book/’, views.book, name=’book’), path(’movie/’, views.movie, name=’movie’), path(’book/detail/<book_id>/<catgray>/’, views.book_detail, name=’detail’), ]
3、APP的views.py文件如下:
from distutils.command import register from django.shortcuts import render, reverse, redirectfrom django.http import HttpResponse def index(request): return render(request, ’index.html’, {’articles’: 18}) def login(request): return HttpResponse('注冊頁面') def book(request): return HttpResponse('讀書頁面') def movie(request): return HttpResponse('電影頁面') def book_detail(request, book_id, catgray): text = ’文章詳情頁,該文章ID是:%s,分類是:%s’ % (book_id, catgray) return HttpResponse(text)
4、index.html文件如下:
<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Title</title></head><body> <ul> <li><a href='http://www.hdgsjgj.cn/' rel='external nofollow' >首頁</a></li> <li><a href='http://www.hdgsjgj.cn/bcjs/{% url ’login’ %}?next=asd/ ' rel='external nofollow' >登錄</a></li> # 點讀書就會調(diào)到,讀書頁,路徑 <li><a href='http://www.hdgsjgj.cn/bcjs/{% url ’book’ %}' rel='external nofollow' rel='external nofollow' >讀書</a></li> # 在這里,直接寫name,就能找到urls文件中對應(yīng)的路由 <li><a href='http://www.hdgsjgj.cn/bcjs/{% url ’book’ %}' rel='external nofollow' rel='external nofollow' >讀書</a></li> <li><a href='http://www.hdgsjgj.cn/bcjs/{% url ’movie’ %}' rel='external nofollow' >電影</a></li> <li><a href='http://www.hdgsjgj.cn/bcjs/{% url ’detail’ book_id=’1’ catgray=2 %}' rel='external nofollow' >最火的一篇文章</a></li></ul> </body></html>
到此這篇關(guān)于Django模板標簽中url使用詳解(url跳轉(zhuǎn)到指定頁面)的文章就介紹到這了,更多相關(guān)Django url使用內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 如何用python開發(fā)Zeroc Ice應(yīng)用2. Python中re模塊的常用方法總結(jié)3. ASP錯誤捕獲的幾種常規(guī)處理方式4. python基于opencv批量生成驗證碼的示例5. npm下載慢或下載失敗問題解決的三種方法6. ASP編碼必備的8條原則7. 使用Spry輕松將XML數(shù)據(jù)顯示到HTML頁的方法8. python+requests+pytest接口自動化的實現(xiàn)示例9. python用pyecharts實現(xiàn)地圖數(shù)據(jù)可視化10. python軟件測試Jmeter性能測試JDBC Request(結(jié)合數(shù)據(jù)庫)的使用詳解