flask框架下的jinja2模板引擎(1)(模板渲染)

#轉載請留言聯繫javascript

  • 模板是什麼?

在 flask 框架中,視圖函數有兩個做用:處理業務邏輯和返回響應內容。在大型應用中,把業務邏輯和表現內容放在一塊兒,會增長代碼的複雜度和維護成本。模板做用便是承擔視圖函數的另外一個做用,即返回響應內容。css

  • 模板實際上是一個包含響應文本的文件,其中用佔位符(變量)表示動態部分,告訴模板引擎其具體的值須要從使用的數據中獲取
  • 使用真實值替換變量,再返回最終獲得的字符串,這個過程稱爲「渲染」
  • Flask是使用 Jinja2 這個模板引擎來渲染模板

使用模板的好處:html

  • 視圖函數只負責業務邏輯和數據處理(業務邏輯方面)
  • 而模板則取到視圖函數的數據結果進行展現(視圖展現方面)
  • 代碼結構清晰,耦合度低

 

  • Jinja2是什麼?

Jinja2 是 Python 下一個被普遍應用的模板引擎,是由Python實現的模板語言,他的設計思想來源於 Django 的模板引擎,並擴展了其語法和一系列強大的功能,其是Flask內置的模板語言。java

下面經過一個簡單的示例來看下用了 Jinja2 模塊引擎後,flask 框架怎麼寫?python

目錄以下:web

項目文件夾
├── static
│   ├── xxx.css
│   └── xxx.js
├── templates
│   └── example.html
└── web.pyflask

其中xxx.css和xxx.js是example依賴的靜態資源。app

首先,web.py 的大體寫法:框架

from flask import Flask
from flask import render_template

app=Flask(__name__,static_folder="static",template_folder="templates")

@app.route("/")
def index():
    return render_template("example.html",name="chichung")    #後面跟鍵值對,對模板的替換 if __name__ == '__main__':
    app.run()

render_templates 就是 jinja2 對模板的「渲染」。函數

而後,example.html 的大體寫法:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <link rel="stylesheet" type="text/css" href={{ url_for("static",filename="xxx.css") }}>
 7     <script type="text/javascript" src={{ url_for("static",filename="xxx.js") }}></script>
 8 </head>
 9 <body>
10     <p>{{ name }}</p>
11 </body>
12 </html>

重點在六、七、10行。

第6行是導入 css 文件。

第7行是導入 js 文件。

第10行是把值替換到 name 裏。

 

  • jinja2 遍歷列表渲染

web.py 以下:

from flask import Flask,render_template

app=Flask(__name__,static_folder="static",template_folder="templates")

@app.route("/")
def index():
    fruit=["蘋果","芒果","香蕉","葡萄"]return render_template("005.html",fruit=fruit)

if __name__ == '__main__':
    app.run()

html 以下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <ul>
        {% for item in fruit %}
        <li>{{ item }}</li>
        {% endfor %}
    </ul>
</body>
</html>

拓展1:

{{ fruit.1 }}    取 fruit 列表的第二位數

同理能夠寫成{{ fruit[1] }}

拓展2:

  • 在一個 for 循環塊中你能夠訪問這些特殊的變量:
變量 描述
loop.index 當前循環迭代的次數(從 1 開始)
loop.index0 當前循環迭代的次數(從 0 開始)
loop.revindex 到循環結束須要迭代的次數(從 1 開始)
loop.revindex0 到循環結束須要迭代的次數(從 0 開始)
loop.first 若是是第一次迭代,爲 True 。
loop.last 若是是最後一次迭代,爲 True 。
loop.length 序列中的項目數。
loop.cycle 在一串序列間期取值的輔助函數。見下面示例程序。

loop.cycle示例:

{% for post in posts%}

{{loop.cycle('odd','even')}} {{post.title}}

{% endfor %}

其中 posts=[1,2]

輸出結果爲:

odd 1

even 2

 

  • jinja2遍歷字典渲染

web.py 以下:

from flask import Flask,render_template

app=Flask(__name__,static_folder="static",template_folder="templates")

@app.route("/")
def index():
    info={"name":"chichung","fav":"code,cook,sleep","height":177}
    return render_template("005.html",info=info)

if __name__ == '__main__':
    app.run()

html 以下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <ul>
        {% for k,y in info.items() %}    {# 注意有.items #} <li>{{ k }}的值是{{ y }}</li>
        {% endfor %}
    </ul>
</body>
</html>

拓展:

{{ info.k }}    去 info 字典,k 鍵對用的值

同理,能夠寫成 {{ info[k] }}

 

  • jinja2條件渲染

web.py 以下:

from flask import Flask,render_template

app=Flask(__name__,static_folder="static",template_folder="templates")

@app.route("/")
def index():
    return render_template("006.html",num=10)

if __name__ == '__main__':
    app.run()

html 以下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    {% if num == 5 %}
        <h1>後臺的數據是5</h1>
    {% elif num == 1 %}
        <h1>後臺的數據是1</h1>
    {% else %}
        <h1>後臺的數據不是1也不是5</h1>
    {% endif %}
</body>
</html>
相關文章
相關標籤/搜索