Django模板系統:Template

来源:https://www.cnblogs.com/zengyi1995/archive/2019/06/24/11079537.html
-Advertisement-
Play Games

一、模板常用語法 1.1 變數 1. 符號:{{ }} 表示變數,在模板渲染的時候替換成值 使用方式:{{ 變數名 }}:變數名由字母數字和下劃線組成 點(.)在模板語言中有特殊的含義,用來獲取對象的相應屬性值 註意:當模板系統遇到一個(.)時,會按照如下的順序去查詢: 在字典中查詢 屬性或者方法 ...


一、模板常用語法

1.1 變數

  1. 符號:{{ }}
    • 表示變數,在模板渲染的時候替換成值
    • 使用方式:{{ 變數名 }}:變數名由字母數字和下劃線組成
    • 點(.)在模板語言中有特殊的含義,用來獲取對象的相應屬性值
    • 註意:當模板系統遇到一個(.)時,會按照如下的順序去查詢:
      • 在字典中查詢
      • 屬性或者方法
      • 數字索引

1.2 內置filter

  1. filter:過濾器,用來修改變數的顯示結果

    • 語法: {{ value|filter_name:參數 }}
    • ':'左右沒有空格沒有空格沒有空格
  2. 內置過濾器

    • default:預設值

      • 語法:{{ value|default:"nothing"}}
      • 如果value值沒傳的話就顯示nothing
      • 補充:TEMPLATES的OPTIONS可以增加一個選項:string_if_invalid:'找不到',可以替代default的的作用
    • filesizeformat:文件大小,將值格式化為可讀的文件尺寸

      • 語法:{{ value|filesizeformat }}
      • 如,value=123456789,輸出將會是 117.7 MB
    • add:給變數加參數

      • 語法:{{ first|add:second }}
      • 優先看是否能轉化為數字相加,其次是字元串拼接
      • 如果都是列表,相當於extend,迴圈加入
    • length:返回長度

      • 語法:{{ value|length }}
      • 返回value的長度,如,value=['a', 'b', 'c', 'd']的話,就顯示4
    • slice:切片

      • 語法:{{value|slice:"2:-1"}}
    • first / last:取第一個/最後一個元素

      • 語法:
        • 取第一個元素:{{ value|first }}
        • 取最後一個元素:{{ value|last }}
    • join:使用字元串拼接列表

      • 語法:{{ value|join:" // " }}
    • truncatechars:截斷,按照字元計數

      • truncatewords:按照字母計數,不能識別中文
      • 如果字元串字元多於指定的字元數量,那麼會被截斷
      • 截斷的字元串將以可翻譯的省略號序列(...)結尾
      • 參數:截斷的字元
      • 語法:{{ value|truncatechars:9}}
    • date:日期格式化

      • 語法:{{ value|date:"Y-m-d H:i:s"}}

      • 在settings.py中配置:

        USE_L10N = False
        
        DATETIME_FORMAT = 'Y-m-d H:i:s'    # datetime類型
        DATE_FORMAT = 'Y-m-d'            # date類型
        TIME_FORMAT = 'H:i:s'            # time類型
      • 配置後,使用{{now}}可以實現日期格式化

        • 其中,'now':datetime.datetime.now()
    • safe:告訴django這段代碼是安全的,不需要轉義

      • 語法:{{ value|safe}}
      • 如,value = "<a href='#'>點我</a>"

1.3 自定義filter

  1. 在app下創建一個名為templatetags的python包

  2. 在templatetags中創建py文件,文件名自定義(my_tags.py);

  3. 在py文件中寫:

    from django import template
    register = template.Library()        # register也不能變
  4. 寫函數+裝飾器

    @register.filter
    def add_xx(value, arg):          # 最多有兩個
        return '{}-{}'.format(value, arg)
    
    @register.filter(name='adds')    # 相當於更改了函數名,使用時,使用新的函數名
  5. 在模板文件中使用,html文件

    {% load my_tags %}
    {{ 'alex'|add_xx:'dsb' }}
  6. 註意:

    • 為避免出錯,templatetags最好是一個Python包,並且名稱不能更改
    • register名稱也不能更改,必要時需要重啟項目
    • Python包下的init中可能有其他內容django不能識別,導致出錯,可以直接刪除內容

1.4 標簽tag

  1. 符號:{% %}

  2. for迴圈

    <ul>
    {% for user in user_list %}
        <li>{{ user.name }}</li>
    {% endfor %}
    </ul>
    • forloop:字典形式
    Variable Description
    forloop.counter 當前迴圈的索引值(從1開始)
    forloop.counter0 當前迴圈的索引值(從0開始)
    forloop.revcounter 當前迴圈的倒序索引值(到1結束)
    forloop.revcounter0 當前迴圈的倒序索引值(到0結束)
    forloop.first 當前迴圈是不是第一次迴圈(布爾值)
    forloop.last 當前迴圈是不是最後一次迴圈(布爾值)
    forloop.parentloop 本層迴圈的外層迴圈
    • for ... empty
    {% for book in all_books %}
        <tr>
         .....
        </tr>
    {% empty %}
        <td>沒有相關的數據</td>
    {% endfor %}
  3. if判斷

    • if語句支持 and 、or、==、>、<、!=、<=、>=、in、not in、is、is not判斷
    {% if 條件1  %}
     xxx
    {% elif 條件2  %}
        xxx
    {% else  %}
     xxxxx
    {% endif %}
    • 連續判斷
      • python中,10>5>1 --> 10>5 and 5>1 --> true
      • js中,10>5>1 --> true>1 --> 1>1 --> false
      • 模板中,不支持連續連續判斷 也不支持算數運算(可使用過濾器)
  4. with:給變數重命名,但只在with區域內生效

    {% with hobby.2 as talk %}
    {# 相當於 {% with talk=hobby.2 %},其中=兩邊不能有空格 #}
     {{ talk }}
    {% endwith %}
  5. csrf_token

    • 該標簽用於跨站請求偽造保護
      • csrf:跨站請求偽造
    • 使用方式:在form表單中寫上{% csrf_token %}
    • 這樣就不用在settings中註釋含csrf的中間件了

1.5 註釋

  • 符號:{# 要註釋的內容 #}

  • 快捷鍵:Ctrl + ?

    {# 要註釋的內容 #}

二、母板和繼承

2.1 母板

  1. 母板就是一個普通的html,提取多個頁面的公共部分,通過定義block塊來實現

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="x-ua-compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title>Title</title>
        {% block page-css %}
    
        {% endblock %}
    </head>
    <body>
        <h1>這是母板的標題</h1>
        {% block page-main %}
    
        {% endblock %}
        <h1>母板底部內容</h1>
        {% block page-js %}
    
        {% endblock %}
    </body>
    </html>
  2. block塊:

    {% block 塊名 %}
    
    {% endblock %}
  3. 註意:我們通常會在母板中定義頁面專用的CSS塊和JS塊,方便子頁面替換

2.2 繼承

  1. 子頁面繼承母板:{% extends '母板html' %}

    {% extends 'layouts.html' %}
  2. 子頁面通過重寫block塊,來替換母板中相應的內容

    {% block page-main %}
        <p>世情薄</p>
        <p>人情惡</p>
        <p>雨送黃昏花易落</p>
    {% endblock %}

2.3 註意

  1. {% extends 'base.html' %}要寫在第一行,前面不要有內容,否則內容會顯示出來
  2. {% extends 'base.html' %}中的'base.html' 必須加上引號,不然會被當做變數去查找
  3. 子頁面把要顯示的內容寫在block塊中,否則不會顯示出來
  4. 多個位置有獨特內容,可以定義多個block塊,特殊:定義css、js塊等

三、組件

  1. 組件:一小段html代碼段

  2. 可以將常用的頁面內容如導航條,頁尾信息等組件保存在單獨的文件中,然後在需要使用的地方導入

    {% include 'navbar.html' %}

四、靜態文件相關

  1. 目的:更改setting中靜態文件的別名時,不影響在更改之前的靜態文件的引用,即引用會跟隨別名的更改而自動更改,這樣就不會報錯了

  2. 方法一:使用static,原本路徑:/static/images/hi.jpg

    {% load static %}
    <img src="{% static "images/hi.jpg" %}" alt="Hi">
    • 文件多處被用到可以存為一個變數
    {% load static %}
    {% static "images/hi.jpg" as myphoto %}
    <img src="{{ myphoto }}">
  3. 方法二:使用get_static_prefix,原本路徑:/static/images/hi.jpg

    {% load static %}
    <img src="{% get_static_prefix %}images/hi.jpg" alt="Hi">
    
    {# 補充:獲取別名 #}
    {% get_static_prefix %}
    • 文件多處被用到可以存為一個變數
    {% load static %}
    {% get_static_prefix as STATIC_PREFIX %}
    <img src="{{ STATIC_PREFIX }}images/hi.jpg" alt="Hi">

五、自定義simple_tag

  1. 和自定義filter類似,區別:接收的參數更靈活,能接收萬能參數

  2. 定義註冊simple_tag

    @register.simple_tag
    def join_str(*args, **kwargs):
        return '{} - {} '.format('*'.join(args), '$'.join(kwargs.values()))
    
    @register.simple_tag(name='join')    # 相當於更改了函數名,使用時,使用新的函數名
  3. 使用自定義simple_tag

    {% load my_tags %}
    {% join_str '1' '2' k1='3' k2='4' %}

六、inclusion_tag

  1. 在app下的templatetags(python包)中創建py文件,文件名自定義(my_inclusion.py);

  2. 在py文件中寫:

    from django import template
    register = template.Library()        # register也不能變
  3. 寫函數+裝飾器

    @register.inclusion_tag('result.html')
    # result.html 是內容的html
    def show_results(n):
        n = 1 if n < 1 else int(n)
        data = ["第{}項".format(i) for i in range(1, n+1)]
        return {"data": data}
  4. 在result.html中寫:

    <ul>
        {% for choice in data %}
        <li>{{ choice }}</li>
        {% endfor %}
    </ul>
  5. 在模板文件中使用

    {% load my_inclusion %}
    {% show_results 10 %}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 昨天的問題解決了,用戶界面一分為三,原本的用戶頁面變成了現在的瀏覽歷史界面,並多了一個修改信息界面和收貨地址設置界面。同時,購物車和訂單的代碼完善,之前的bug進行修改。前臺顯示算是完成了。還差管理員的管理界面,以及填充資料庫了。哦,對了,我今天新加了一個表,專門用來存收貨地址,和用戶表是n對1的。 ...
  • 摘要: 根評論(文章的普通評論) 子評論(一篇文章中評論的評論) 一、根評論(普通的評論) ①文章詳情下方點贊的下方評論區頁面的搭建(渲染): article_detail.html頁面: 這裡提交評論的數據請求到後端,需要新建一個路由專門處理評論數據 urls.py路由文件 先看看效果 點擊提交評 ...
  • 與C表達式 bool ? a : b類似,但是bool and a or b,當 a 為假時,不會象C表達式 bool ? a : b 一樣工作 應該將 and-or 技巧封裝成一個函數: def choose(bool, a, b): return (bool and [a] or [b])[0] ...
  • 課程作業: ...
  • 一、SQLAlchemy簡介 SQLAlchemy是Python SQL工具包和對象關係映射器,是python中最著名的ORM(Object Relationship Mapping)框架,它簡化了應用程式開發人員在原生SQL上的操作,使開發人員將主要精力都放在程式邏輯上,從而提高開發效率。它提供了 ...
  • 一、變數作用域 當程式定義一個變數時,這個變數是有它的作用範圍的,變數的作用範圍稱為變數的作用域。根據變數的位置,分為兩種: 局部變數:局部變數就是在函數中定義的變數,包括參數,都是局部變數,局部離開函數後,將不能被訪問。 全局變數:不在函數內定義、全局範圍內定義的變數,都是全局變數,全局變數可以在 ...
  • 前面介紹了怎樣通過Socket在客戶端與服務端之間傳輸文本,當然Socket也支持在客戶端與服務端之間傳輸文件,因為文件本身就是通過I/O流實現讀寫操作的,所以在套接字的輸入輸出流中傳輸文件真是再合適不過了。只是套接字屬於長連接,倘若Socket一直不關閉,連接將總是處於就緒狀態,也就無法判斷文件數 ...
  • 封裝和@property 一、複習 1、介面類和抽象類 python中沒有介面類,有抽象類,abc模塊中的metaclass=ABCMeta,@abstructmethod,本質是做代碼規範用的,希望在子類中實現和父類方法名完全一樣的方法 在Java的角度上是有區別的: Java本來支持單繼承,所以 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...