目錄
- 一、標(biāo)簽語(yǔ)法
- 二、常見(jiàn)標(biāo)簽
- 三、標(biāo)簽例子
- 四、模板的繼承
一、標(biāo)簽語(yǔ)法
由%}和 {% 來(lái)定義的,例如:{%tag%} {%endtag%},完整的標(biāo)簽有開(kāi)始就有結(jié)束,如條件語(yǔ)句,有條件判斷的開(kāi)始,也對(duì)應(yīng)有條件的結(jié)束。
二、常見(jiàn)標(biāo)簽
if條件判斷
- if/elif/else:可以使用and/or/in/not/==/!=/=/>=,來(lái)進(jìn)行判斷。ifequal/ifnotequal
for循環(huán)
- for ... in ...:和python中的用法一樣。
- forloop.counter:當(dāng)前迭代的次數(shù),下標(biāo)從1開(kāi)始。1,2,3....
- forloop.counter0:當(dāng)前迭代的次數(shù),下標(biāo)從0開(kāi)始。指定下標(biāo),上面一種不指定的默認(rèn)從1開(kāi)始
- forloop.revcounter:與forloop.counter一樣,不同在于下標(biāo)呈倒序,從大到小。
- forloop.revcounter0:forloop.counter0一樣,不同在于下標(biāo)呈倒序,從大到小。
- forloop.frist:返回一個(gè)布爾值,如果是第一次迭代,返回true,否則返回false。
- forloop.last:返回布爾值,如果是最后一次迭代,返回true,否則返回false
- forloop.parentloop:如果發(fā)生多層for循環(huán)嵌套,那么這個(gè)變量返回的是上一層的for。
- for...in...empty...:如果沒(méi)有數(shù)據(jù),跳到empty中。
其他重要標(biāo)簽
load:加載第三方標(biāo)簽。常見(jiàn)用的是{% load static%}
url:返回一個(gè)命名了的URL的絕對(duì)路徑。
with:緩存一個(gè)變量。
autoescape:開(kāi)啟和關(guān)閉自動(dòng)轉(zhuǎn)義。
三、標(biāo)簽例子
if條件標(biāo)簽代碼例子
# views.py文件
def testif(request):
complex = {
'name':'python',
}
return render(request,'標(biāo)簽-if.html',complex)
# urls.py文件
urlpatterns = [path('testif/', views.testif),]
!--if標(biāo)簽?zāi)0逦募?->
!DOCTYPE html>
html lang="en">
head>
meta charset="UTF-8">
title>if模板/title>
style>span{font-size: 40px;color: #d70b35;}/style>
/head>
body>
{% if name == "python" %}
這是span>{{name}}/span>頁(yè)面
{% elif name == "django" %}
這是span>{{name}}/span>頁(yè)面
{% else %}
確定是span>{{name}}/span>嗎?
{% endif %}
/body>
/html>
for 循環(huán)標(biāo)簽代碼例子
# views.py文件
def testfor(request):
ls = ['1','2','3','4','5']
complex ={
'ls':ls,
}
return render(request,'標(biāo)簽-for.html',complex)
# urls.py文件
urlpatterns = [path('testfor/', views.testfor),]
!--for標(biāo)簽?zāi)0逦募?->
!DOCTYPE html>
html lang="en">
head>
meta charset="UTF-8">
title>for模板/title>
style>a{font-size: 25px;}/style>
/head>
body>
{% for i in ls %}
{% if forloop.counter == 3 %}
a rel="external nofollow" >百度/a>br>
{% else %}
a rel="external nofollow" >CSDN/a>br>
{% endif %}
{% endfor %}
/body>
/html>
url頁(yè)面轉(zhuǎn)換標(biāo)簽例子
注意:親測(cè)。。。使用url頁(yè)面轉(zhuǎn)換標(biāo)簽的時(shí)候,注意模板中的引用模板鏈接名稱應(yīng)該是urlpatterns中path的name的值,如果是直接使用接口名稱會(huì)報(bào)錯(cuò)
錯(cuò)誤演示
正確演示
代碼
## views.py文件
def testurl(request):
return render(request,'URL頁(yè)面轉(zhuǎn)換.html')
## urls.py 文件
urlpatterns = [path('testurl/', views.testurl),]
!-- url標(biāo)簽?zāi)0逦募? -->
!DOCTYPE html>
html lang="en">
head>
meta charset="UTF-8">
title>URL頁(yè)面轉(zhuǎn)換/title>
style>
a{font-size: 25px;color: #10e59d
}
/style>
/head>
body>
a href="/index/" rel="external nofollow" >index模板/a>br>
a href="{% url 'temp' %}" rel="external nofollow" >使用ur標(biāo)簽temp模板/a>br>
a href="{% url 'test' 999 %}" rel="external nofollow" >使用url標(biāo)簽進(jìn)行添加參數(shù)傳遞/a>
/body>
/html>
四、模板的繼承
Django模版引擎中最強(qiáng)大也是最復(fù)雜的部分就是模版繼承了。使用模板的作用在于提高代碼的復(fù)用性。 模版繼承可以讓你創(chuàng)建一個(gè)基本的“骨架”模版,它包含您站點(diǎn)中的全部元素,并且可以定義能夠被子模版覆蓋的 blocks。
模板繼承使用extends標(biāo)簽實(shí)現(xiàn)。通過(guò)使用block來(lái)給子模板開(kāi)放接口。
1、extends必須是模板中的第一個(gè)出現(xiàn)的標(biāo)簽。
2、子模板中的所有內(nèi)容,必須出現(xiàn)在父模板定義好的block中,否則django將不會(huì)渲染。
3、如果出現(xiàn)重復(fù)代碼,就應(yīng)該考慮使用模板。
4、盡可能多的定義block,方便子模板實(shí)現(xiàn)更細(xì)的需求。
5、如果在某個(gè)block中,要使用父模板的內(nèi)容,使用block.super獲取。
代碼例子
!-- 模板的引用頁(yè) -->
!DOCTYPE html>
html lang="en">
head>
meta charset="UTF-8">
title>引用頁(yè)/title>
style>
.p2{
font-size: 25px;
color: blue;
}
/style>
/head>
body>
h style="font-size:40px;color:red;">這是引用頁(yè)的內(nèi)容/h>
/body>
/html>
!-- 模板的繼承頁(yè) -->
!DOCTYPE html>
html lang="en">
head>
meta charset="UTF-8">
title>{% block title %}默認(rèn)標(biāo)題{% endblock %}/title>
style>
.p1{font-size: 30px;color: #8dff50
}
span{
font-size: 25px;
color: darkkhaki;
}
/style>
/head>
body>
{% block content %}
span>這是默認(rèn)內(nèi)容/span>
{% endblock %}
{% block demo %}
span>這是演示內(nèi)容/span>
{% endblock %}
/body>
/html>
!-- 模板繼承的主頁(yè) -->
{% extends '模板/繼承頁(yè).html' %}
{% block title %}主頁(yè)(繼承與引用){% endblock %}
{% block content %}
p class="p1">這是通過(guò)繼承父類的:{{ block.super }}/p>br>
p class="p1">這是子模版的內(nèi)容,沒(méi)有寫block就不會(huì)顯示/p>br>
{% endblock %}
{% block demo %}
p class="p2">這是通過(guò)include引用的其他模板的內(nèi)容:{% include '模板/引用頁(yè).html' %}/p>
{% endblock %}
演示結(jié)果
通過(guò)設(shè)置css樣式,可以看出,繼承主頁(yè)繼承和引用了繼承模板文件及引用模板文件中的css樣式。
到此這篇關(guān)于Python Django框架介紹之模板標(biāo)簽及模板的繼承的文章就介紹到這了,更多相關(guān)Django框架之模板標(biāo)簽及模板的繼承內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- python之django路由和視圖案例教程
- python Django框架快速入門教程(后臺(tái)管理)
- Python django中如何使用restful框架
- Python Django搭建文件下載服務(wù)器的實(shí)現(xiàn)
- 一篇文章帶你自學(xué)python Django