欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python全棧之模板渲染詳解

 更新時間:2022年02月15日 09:16:48   作者:熬夜泡枸杞  
這篇文章主要為大家詳細介紹了Python全棧之模板渲染,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

1. 標(biāo)簽

{% 標(biāo)簽 %}

1.1 for循環(huán)標(biāo)簽

<ul>
<!-- 可迭代對象都可以用循環(huán) -->
<!-- 循環(huán)列表 -->
    {% for foo in hobby %}
        <li>{{ foo }}</li>
        {% empty %}  <!-- 當(dāng)循環(huán)的數(shù)據(jù)為空或者沒有這個變量時顯示empty下面的內(nèi)容 -->
        <h1>啥也沒有</h1>
    {% endfor %}
</ul>

<ul>
    <!-- 循環(huán)字典 -->
    {% for foo in d1 %}  <!-- 只能獲取鍵 -->
        <li>{{ foo }}</li>
    {% endfor %}
    {% for key,value in d1.items %}  <!-- 獲取鍵值對,items.keys,values都能用 -->
        <li>{{ key }} -- {{ value }}</li>
    {% endfor %}

</ul>

forloop對象

<ul>
    {% for foo in hobby %}
		forloop  循環(huán)標(biāo)簽對象,通過counter屬性可以來記錄循環(huán)次數(shù) 
        <li>{{ forloop.counter }}---{{ foo }}</li> 從1開始計數(shù)
        <li>{{ forloop.counter0 }}---{{ foo }}</li> 從0開始計數(shù)
        <li>{{ forloop.revcounter }}---{{ foo }}</li> 倒序,從1開始計數(shù)
        <li>{{ forloop.revcounter0 }}---{{ foo }}</li> 倒序,從0開始計數(shù)
        <li>{{ forloop.first }}---{{ foo }}</li> 如果是第一次循環(huán),就得到True 
        <li>{{ forloop.last }}---{{ foo }} </li>  如果是最后一次循環(huán),就得到True,其他為False 

    {% endfor %}
</ul>
   
    {% for key,value in hobby2.items %}
        forloop.parentloop 統(tǒng)計外層循環(huán)對象的循環(huán)次數(shù)
        {% for v in value %}
            <li>{{ forloop.parentloop.counter }} -- {{ forloop.counter }} -- {{ v }}</li>
        {% endfor %}

    {% endfor %}
    
reversed 倒序循環(huán)
 <ul>
    {% for foo in hobby reversed %}
        <li>{{ foo }} </li>

    {% endfor %}
</ul>

1.2 if標(biāo)簽

{% if age > 18 %}
    <h1>太老了</h1>
{% elif age == 18 %}
    <h1>還行</h1>
{% else %}
    <h1>挺嫩</h1>
{% endif %}
{% if age > 18 or number > 100 %} <!-- 符號兩邊必須有空格 -->
    <h1>太老了</h1>
{% elif age == 18 %}
    <h1>還行</h1>
{% else %}
    <h1>挺嫩</h1>
{% endif %}
{% if hobby|length > 3 %} <!-- 可以配合過濾器來使用 -->
    <h1>愛好還挺多</h1>
{% else %}
    <h1>愛好不夠多</h1>
{% endif %}

f語句支持 and 、or、==、>、<、!=、<=、>=、in、not in、is、is not判斷,注意條件兩邊都有空格。

注意:不能像下面這樣寫

{% if a > b > c %}
...
{% endif %}

Django的模板語言中屬性的優(yōu)先級大于方法

d2 = {'items': [11,22,33]}
優(yōu)先使用items屬性,不使用items方法,容易導(dǎo)致錯誤
<ul>
    {% for key,v in d2.items %}
        <li>{{ key }} -- {{ v }}</li>
    {% endfor %}
</ul>

1.3 with標(biāo)簽

給調(diào)用過程比較長的數(shù)據(jù)起別名的.

寫法1.
{% with hobby2.xx.0 as kk %}
    <h1>{{ kk }}</h1>
    <h2>{{ kk }}</h2>
{% endwith %}
{% with kk=hobby2.xx.0 %}
    <h1>{{ kk }}</h1>
    <h2>{{ kk }}</h2>
{% endwith %}

1.4 csrf token標(biāo)簽

<form action="" method="post">
    {% csrf_token %}  <!-- 加上這個標(biāo)簽之后,post請求就能通過django的csrf認證機制,就不需要注釋settings的配置了 -->
    <input type="text" name="uname">
    <input type="submit">
</form>

2. 模板繼承

先創(chuàng)建一個母版(模板)

比如base.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
        .c1{
            background-color: pink;
            height: 40px;
        }
        .left-menu{
            background-color: tan;
            width: 200px;
            min-height: 600px;
        }
        .item{
            background-color: yellow;
            height: 40px;
            border-bottom: 1px solid red;
        }
        .left{
            float: left;
        }
        .right{
            float: left;
        }
    </style>
    {% block css %}
    {% endblock %}
</head>
<body>
<div class="nav">
    <div class="c1">
        <a href="">32官網(wǎng)</a>
        <span>性感荷官, 在線發(fā)牌</span>
    </div>
</div>
<div class="main">
    <div class="left">
    <div class="left-menu">
        <div class="menu1 item">
            <a href="/t1/">菜單1</a>  <!-- 寫相對路徑時,前面的斜杠必須寫 -->
        </div>
        <div class="menu2 item">
            <a href="/t2/">菜單2</a>
        </div>
        <div class="menu3 item">
            <a href="/t3/">菜單3</a>
        </div>
    </div>
</div>
<div class="right">
    <div class="content">
        {% block content %}
            <h1>基礎(chǔ)模板</h1>
        {% endblock %}
    </div>
</div>
</div>
</body>
{% block js %}
{% endblock %}
</html>

在模板中預(yù)留block塊(叫做 鉤子)

{% block content %}
	<h1>基礎(chǔ)模板</h1>
{% endblock %}

子頁面中繼承模板extends

并重寫模板中預(yù)留的block塊中的內(nèi)容

{{ block.super }}顯示模板的內(nèi)容

{% extends 'base.html' %}
{% block css %}
    <style>
        .c1{
            background-color: green;
            height: 40px;
        }
    </style>
{% endblock %}
{% block content %}
    <h1>性感美女,在線指導(dǎo)</h1>
    {{ block.super }} <!-- 顯示模板的內(nèi)容 -->
{% endblock %}

block塊的寫法

{% block content %}
...
{% endblock %}
{% block content %}
...
{% endblock content %}    可以指定endblock的名稱,起到一個提示作用

3. 組件

一個完整功能的模塊,其他頁面如果想使用,就直接以組件的形式引入

比如創(chuàng)建一個zujian.htmlm,內(nèi)容如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
        .c1{
            background-color: pink;
            height: 40px;
        }
    </style>
</head>
<body>

<div class="nav">
    <div class="c1">
        <a href="">32官網(wǎng)</a>
        <span>性感荷官, 在線發(fā)牌</span>
    </div>
</div>
</body>
</html>

在home.html中引入一下include

在頁面什么位置引入,組件效果就生成到什么位置

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<h1>這是home頁面</h1>
{% include 'zujian.html' %}

</body>
</html>

靜態(tài)文件的配置流程

1 在settings.py文件中加上如下配置

STATIC_URL = '/static/'  #別名,映射到STATICFILES_DIRS配置的靜態(tài)文件存放路徑,#那么引入靜態(tài)文件時,我們使用別名路徑來寫,如果使用別名路徑, 那么修改靜態(tài)文件夾名稱之后,也不會影響靜態(tài)文件的返回# STATIC_URL = '/abc/'  別名可以修改的STATICFILES_DIRS = [    os.path.join(BASE_DIR, 'statics'),]STATIC_URL = '/static/'  #別名,映射到STATICFILES_DIRS配置的靜態(tài)文件存放路徑,
#那么引入靜態(tài)文件時,我們使用別名路徑來寫,如果使用別名路徑, 那么修改靜態(tài)文件夾名稱之后,也不會影響靜態(tài)文件的返回
# STATIC_URL = '/abc/'  別名可以修改的
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'statics'),
]

2 在項目根目錄下創(chuàng)建一個文件夾,名稱隨意,比如叫做statics

3 在html文件中引入(兩種方式)

方式1

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" href="/static/css/xx.css"> 方式1   直接寫別名路徑開頭
</head>
<body>
<div class="c1">xxx</div>

</body>
</html>

方式2:

{% load static %}   先load一下static
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" href="{% static 'css/xx.css' %}" > 方式2

</head>
<body>
<div class="c1">xxx</div>

</body>
</html>

4. 自定義過濾器

1 在應(yīng)用文件夾中創(chuàng)建一個叫做templatetags的文件夾(注意,名稱必須是它)

2 在templatetags文件夾中創(chuàng)建一個py文件,名稱隨意,比如叫做mytag.py

3 在mytag.py文件中寫如下內(nèi)容

from django import template
register = template.Library()  #注冊器,變量名稱必須叫register
@register.filter   #過濾器
def xx(v1):  #第一參數(shù)是使用過濾器時,管道符前面的數(shù)據(jù) <h1>{{ name|xx }}</h1>
	return v1 + 'xx'
@register.filter   #過濾器,至多有兩個參數(shù)
def xx2(v1, v2):  #第一參數(shù)是使用過濾器時,管道符前面的數(shù)據(jù) ,第二個參數(shù)是冒號后面的值,<h1>{{ name|xx:'oo' }}</h1>
	return v1 + 'xx2' + v2

4 在html文件中使用

{% load mytag %}   先load一下我們的mytagpy文件
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<h1>這是home頁面</h1>
{#{% include 'zujian.html' %}#}
<h1>{{ name|xx }}</h1>   #以過濾器的形式使用,這個是一個參數(shù)的
<h1>{{ name|xx2:'oo' }}</h1> # 以過濾器的形式使用,這個是兩個參數(shù)的
</body>
</html>

5. 自定義標(biāo)簽

1 在應(yīng)用文件夾中創(chuàng)建一個叫做templatetags的文件夾(注意,名稱必須是它)

2 在templatetags文件夾中創(chuàng)建一個py文件,名稱隨意,比如叫做mytag.py

3 在mytag.py文件中寫如下內(nèi)容

from django import template
register = template.Library()  #注冊器,變量名稱必須叫register

@register.simple_tag
def tag1(v1, v2 ,v3):  #參數(shù)個數(shù)沒有限制
	return v1 + v2 + v3

4 在html文件中使用

{% load mytag %}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>

<h1>{% tag1 11 22 number %}</h1>  <!-- 先寫標(biāo)簽名稱,然后寫參數(shù),參數(shù)以空格分隔 ,最終得到的tag1的return值 -->
</body>
</html>

6. inclusion_tag 自定義標(biāo)簽

這個可以模擬不同用戶,所看到的功能模塊不一樣,就是用這個實現(xiàn)的

1 在應(yīng)用文件夾中創(chuàng)建一個叫做templatetags的文件夾(注意,名稱必須是它)

2 在templatetags文件夾中創(chuàng)建一個py文件,名稱隨意,比如叫做mytag.py

3 在mytag.py文件中寫如下內(nèi)容

from django import template
register = template.Library()  #注冊器,變量名稱必須叫register
# 通過inclusion_tag來做為裝飾器,并且需要傳入一個參數(shù),這個參數(shù)就是一個html文件(你想做成動態(tài)組件的html文件)
@register.inclusion_tag('zujian2.html')
def dongtai(v1):  #參數(shù)沒有個數(shù)限制
	data = v1  #[11,22,33,44,55,66]
	return {'xx': data }
# zujian2.html會收到定義的inclusion_tag函數(shù)的返回值,然后進行zujian2.html這個動態(tài)組件的模板渲染

zujian2.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
        .left-menu {
            background-color: tan;
            width: 200px;
            min-height: 600px;
        }
        .item {
            background-color: yellow;
            height: 40px;
            border-bottom: 1px solid red;
        }
        .left {
            float: left;
        }
    </style>
</head>
<body>
<div class="left">
        <div class="left-menu">
            {% for item in xx %}  <!-- [11,22,33] ,注意 data這是inclusion_tag函數(shù)的返回值那個字典中的鍵 -->
                <div class="menu1 item">
                    <a href="/t1/">{{ item }}</a>  <!-- 寫相對路徑時,前面的斜杠必須寫 -->
                </div>
            {% endfor %}
        </div>
    </div>

</body>
</html>

4 使用inclusion_tag

basic.html

{% load mytag %}   先load
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
{% dongtai menu_list %}  #最終將渲染好的動態(tài)組件(zujian2.html),通過include引入組件的方式,加載到這里
</body>
</html>

5 在后臺視圖中渲染basic.html頁面是可以傳入動態(tài)數(shù)據(jù)

def basic(request):
	# if user.type == 'admin':
	# menu_list = [11,22,33,44,55,66]
	# else:
	menu_list = [22,33]
	return render(request, 'basic.html',{'menu_list': menu_list})

7. 小提示與小練習(xí)

小提示

自定義標(biāo)簽和過濾器在前后端未分離的項目用的比較多一些
前后端分離的項目用的比較少
@register.inclusion_tag('zujian2.html')
def dongtai(v1):
      data = v1
      return {'xx':data}  # 這個return 相當(dāng)于render(zujian2.html,{'xx':data})

小練習(xí)

頁面效果

在這里插入圖片描述

在這里插入圖片描述

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!    

相關(guān)文章

  • python簡易遠程控制單線程版

    python簡易遠程控制單線程版

    這篇文章主要為大家詳細介紹了python簡易遠程控制單線程版,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • 把Anaconda中的環(huán)境導(dǎo)入到Pycharm里面的方法步驟

    把Anaconda中的環(huán)境導(dǎo)入到Pycharm里面的方法步驟

    這篇文章主要介紹了把Anaconda中的環(huán)境導(dǎo)入到Pycharm里面的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • python實現(xiàn)文法左遞歸的消除方法

    python實現(xiàn)文法左遞歸的消除方法

    這篇文章主要介紹了python實現(xiàn)文法左遞歸的消除的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • 教你使用Python?的?Template?類生成文件報告

    教你使用Python?的?Template?類生成文件報告

    這篇文章主要介紹了用?Python?的?Template?類生成文件報告,在閱讀本文時,您不僅學(xué)習(xí)了Python字符串的基本知識,Template類以及使用它的原因,而且還實現(xiàn)了第一個文件報告腳本,需要的朋友可以參考下
    2022-08-08
  • Python實現(xiàn)對比兩個Excel數(shù)據(jù)內(nèi)容并標(biāo)記出不同

    Python實現(xiàn)對比兩個Excel數(shù)據(jù)內(nèi)容并標(biāo)記出不同

    日常工作中需要對比兩個Excel工作表中的數(shù)據(jù)差異是很不方便的,使用python來做就比較簡單了!本文為大家介紹了python實現(xiàn)對比兩個Excel的數(shù)據(jù)內(nèi)容并標(biāo)記出不同數(shù)據(jù)的示例代碼,需要的可以參考一下
    2022-12-12
  • python操作docx寫入內(nèi)容,并控制文本的字體顏色

    python操作docx寫入內(nèi)容,并控制文本的字體顏色

    今天小編就為大家分享一篇python操作docx寫入內(nèi)容,并控制文本的字體顏色,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • 利用Python獲取趕集網(wǎng)招聘信息前篇

    利用Python獲取趕集網(wǎng)招聘信息前篇

    這篇文章主要為大家分享了如何利用Python獲取趕集網(wǎng)招聘信息的前一篇內(nèi)容,感興趣的小伙伴們可以參考一下
    2016-04-04
  • Python 如何手動編寫一個自己的LRU緩存裝飾器的方法實現(xiàn)

    Python 如何手動編寫一個自己的LRU緩存裝飾器的方法實現(xiàn)

    本文主要介紹了Python如何手動編寫一個自己的LRU緩存裝飾器,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • python使用ctypes調(diào)用擴展模塊的實例方法

    python使用ctypes調(diào)用擴展模塊的實例方法

    在本篇文章里小編給大家整理的是一篇關(guān)于python使用ctypes調(diào)用擴展模塊的實例方法內(nèi)容,需要的朋友們可以學(xué)習(xí)參考下。
    2020-01-01
  • Keras中Conv1D的使用及說明

    Keras中Conv1D的使用及說明

    這篇文章主要介紹了Keras中Conv1D的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評論