Django模板語言(一)


1,Django模板語言

  1.1>基礎語法:1.1.1,變量相關:{{ 變量名 }},1.1.2,邏輯相關{% ... %}

  在Django模板語言中按此語法使用:{{ 變量名 }},當模板引擎遇到一個變量,它將計算這個變量,然后用結果替換掉它本身,變量的命名規則包括任何字母數字以及下划線("_")的組合,變量名稱中不能有空格.變量名稱中不能有空格或標點符號,在模板語言中點(.)有特殊的特殊含義.當模板系統遇到(".")它將按照這個順序去查詢

  字典查詢------>屬性或放法查詢(當屬性和方法沖突的時候)----->數字索引查詢

注意事項:

  1,如果計算結果的值是可調用的,它將被無參數的調用,調用的結果將成為模板的值

  2,如果使用的變量不存在,模板系統將插入string_if_invalid選項的值,他被默認設置為空字符串

view代碼

 

def template_test(request):
    l = [11,22,33]
    d = {"name":"雪雪"}
    class Person(object):
        def __init__(self, name, age):
            self.name = name
            self.age = age
        def dream(self):
            return "%s is dream..." % self.name
    p1 = Person(name= "小雪",age=29)
    p2 = Person(name-"雪人",age=28)
    p3 = Person(name="小雪砸",age=27)
    person_list = [p1, p2, p3]
    return render(request, "template_test.html", {"l":l, "d":d, "person_list":person_list

模板中支持的寫法 

 

 

 

  1.2>filter(過濾器):在Django模板語言中,通過使用過濾器來改變變量的顯示.

    1.2.1>基礎語法:{{ 變量|方法名:"參數" }},使用管道符"|"來應用過濾器,列如:

  {{ name|upper }}會將name變量應用upper過濾器之后再顯示它的值,upper會把文本變成全大寫,

注意事項:

  1>過濾器支持鏈式操作,即一個過濾器的輸出做為另一個過濾器的輸入

  2>過濾器可以接受參數,列如:{{ ret|trucatewords:30 }},這時將ret的前30個詞顯示出來

  3>過濾器參數包含空格,必須引號包裹起來,比如使用逗號和空格去連接一個列表中的元素, 如: {{ list|join:", " }}

  4>"|"左右都不要加空格

  1.3>內置filter過濾器

<1>default:若果一個變量是false或者為空, 使用給定的默認值. 否則,使用變量的值

 

{{ value|default:"nothing" }}

 

<2>length:返回值的長度,作用於字符串和列表

 

{{ value|length }}
返回value的長度,如value=["雪雪","小雪","雪人","小雪砸"],就在瀏覽器顯示長度為4

 

<3>filesizeformat:將值格式化為一個"人類可讀的"文件尺寸(列如"13kb","4.1mb","102bytes"等)

{{ value|filesizeformat }}
如果是1234567789,則輸出將會是117.7mb

<4>slice:切片

{{ value|slice:"2:-1" }}

<5>date:時間格式

{{ value|date:"Y-m-d H:i:s" }}
得到的是年月日,時分秒

<6>safe:原樣輸出如果有html代碼瀏覽器也不會顯示,會把輸入的任何數據按原樣揮着字符串輸出

# 在Django中的模板會對html標簽和JS等語法標簽進行自動轉義,原因顯而易見,這樣是為了安全,
但是有的時候我們可能不希望這些html元素被轉義,比如我們做一些內容平管理系統,后台 的文章中是經過修飾的,
這些修飾可能通過類似於FCKeditor編輯加注了html修飾符的文本,
如果自動轉義,顯示就是自動保護html原文件,為了在Django中關閉html自動轉義有兩種方式,
如果是一個單獨的變量我們可以通過過濾器|safe的方式告訴Django這段代碼是安全的不必轉義 比如:value = "<a href="#">點我</a>"

 

{{  value|safe }}

<7>truncatechars:如果字符串字符多於指定的字符數量, 那么會被截斷的字符串將以可翻譯的省略號序列("...")結尾,不管截取多長,最后有且只有三個點代表三個字符

{{  value|truncatechars:9 }}

<8>cut:移除value中所有給出的變量相同的字符串

{{  value|cut:" " }}  # 移除變量value中所有的空格
如果value變量是:"I miss you",輸出的結果是"Imissyou"

 <9>join:使用字符串裂解列表,列如:str.join[list]

<10>timesince:將日期格式設為自該日期起的時間(列如,"4天","6小時").采用一個 可選參數,它是一個包含用作比較點的日期變量 (不帶參數,比較點為現在) .現在,如果blog_date是表示2006年6月1日08:00的日期實例,則一下將返回"8小時":

{{ blog_date|timesince:comment_date }}

分鍾是使用的最小的單位,對於相對於比較點的未來的任何日期,將返回"0分鍾".

<11>timeuntil:似於timesince,除了它測量從現在開始知道給定日期或時間的時間. 列如,如果今天是2006年6月1號,而conference_date是保留2006年 6月29號的日期實例,則{{ conference_date|timeuntil }}將返回"4周".使用可選參數,它是一個包含用作比較點的日期(而不是現在)的變量, 如果from_date包含2006年6月22日,則以下內容將返回1周:

{{ conference_date|timeuntil:from_date }}

 <11>filter自定義

  1>在APP目錄下創建一個名為templatetags的python包

  2>在上面創建的包內部創建一個python文件:文件名.py

  3>在文件名.py文件中按照固定的格式注冊一個自定義的filter在這個文件里是我們自定義的一些函數

      from django import template

      # 固定寫法, 生成一個注冊實例對象

      register = template.Library()

      @register.filter()  # 告訴Django的模板語言現在注冊一個自定義的filter

      def add_sb(value):

          """

          給任意指定的變量添加sb

          :param value:|左邊被修飾的那個變量

          :return:修飾后的變量內容

          """

          return value + "sb"

      @register.filter()

      def add_str(value,argv):

        return value + argv

    使用:

    1>重啟Django項目

    2>在html頁面中: {% load python文件名 %}  # 從新加載一次

    3>{{ name|add_str:"大好人" }}

 <12>tags:for循環

<ul>
    {% for use in user_info %}
        <li>{{ user.name }}</li>
    {% endif %}
</ul>

for循環可用的一些參數

variable description
forloop.counter 當前循環的索引值,從1開始
forloop.counter0 當前循環的索引值,從0開始
forloop.revcounter 當前循環的倒序索引值(以1結束)
forloop.revcounter0 當前循環的倒序索引值(以0結束)
forloop.first 當前循環是不是第一次循環(返回的是一個布爾值)
forloop.last 當前循環是不是最后一次循環(返回的是一個布爾值)
forloop.parentloop 本層循環的外層循環

for ... empty循環

<ul>    
    {% for user in user_list %}
        <li>{{ user.name }}</li>
    {% empty %}  #在for循環以后沒有符合的數據

        <li>空空如也</li>
    {% endfor %}
</ul>

if ... elif ... else

{% if user_list %}
    用戶人數: {{ user_list|length }}
{% elif black_list|length %}
    黑名單人數:{{ black_list|length }}
{% else %}
    沒有用戶
{% endif %}

if 語句支持and, or, ==, >, <, !=, <=, >=, in, not in, is, is not判斷

with定義一個中間變量  

{% with total=business.employee. count %}
    {{ total }} employee{{ total|pluralize }}
{% endwith %}

<13>csrf_token:這個標簽用於跨站請求偽造保護,在頁面中的form表單中寫上{% csrf_token %}

<14>注釋:{# ... #}

<15>注意事項:

  1,Django的模板語言不支持連續判斷,即不支持一下寫法

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

  2,Django的模板語言中屬性的優先級大於方法

def XXOO(request):
    d = {"a": 1, "b": 2, "c": 3, "items": 100}
    return render(request, "XXOO.html", {"data": d})

如上,我們在使用render方法渲染一個頁面的時候,傳得字典d有 一個key是items並且還有默認的d.items()方法,此時在模板語言中

{{ data.items }}
默認會取到d的items key的值

 2,母板

<!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-min %}

{% endblock %}
<h1>母板底部內容</h1>
{% block page-js %}

{% endblock %}
</body>
</html>

注意:我們通常會在母板定義中頁面專用的CSS塊和JS塊, 方便子頁面替換

繼承母板:在子頁面中在頁面最上方使用下面的語法來繼承母板.

{% extend "layout.html" %}

3,塊:通過使用母板中{% block xxx %}來定義塊,在頁面中通過定義母板中的block,名開對應替換母板中相應內容

{% block page_main %}
    <p>小時候那一雙大手</p>
    <p>牽着溫柔的對我講</p>
    <p>長達以后要去流浪</p>
    <p>一定會看得到遠方</p>
    <p>我的行囊</p>

    <p>背上那沉重的夢想</p>

    <p>是未來的方向</p>

    <p>青春驕縱特別狂妄</p>

    <p>為自由愛上或迷茫</p>

    <p>聽過很多流行歌</p>

    <p>半步成詩的玫瑰破碎后</p>

    <p>妄想去追</p>

    <p>流不同的淚</p>

    <p>垂涎回憶的美</p>
{% endblock %}

注意事項:

  1>{% extends "base.html" %}寫在第一行

  2>{% extends name %}name寫在繼承的母板的名字字符串

  3>自定義的內容寫在block中

  4>定義多個block塊, 一般要有JS CSS

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM