#轉載請留言聯繫javascript
在 flask 框架中,視圖函數有兩個做用:處理業務邏輯和返回響應內容。在大型應用中,把業務邏輯和表現內容放在一塊兒,會增長代碼的複雜度和維護成本。模板做用便是承擔視圖函數的另外一個做用,即返回響應內容。css
使用模板的好處:html
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 裏。
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:
變量 | 描述 |
---|---|
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
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] }}
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>