Python Flask入門之模板
在一般的 Web 程序里,訪問一個地址通常會返回一個包含各類信息的 HTML 頁面。因為我們的程序是動態(tài)的,頁面中的某些信息需要根據(jù)不同的情況來進行調(diào)整,比如對登錄和未登錄用戶顯示不同的信息,所以頁面需要在用戶訪問時根據(jù)程序邏輯動態(tài)生成。
我們把包含變量和運算邏輯的 HTML 或其他格式的文本叫做模板,執(zhí)行這些變量替換和邏輯計算工作的過程被稱為渲染(模板渲染引擎——Jinja2)。
按照默認的設置,F(xiàn)lask 會從程序?qū)嵗谀K同級目錄的 templates 文件夾中尋找模板。
模板基本語法
在模板里,你需要添加特定的定界符將 Jinja2 語句和變量標記出來
下面是三種常用的定界符:
1、{{ … }} 用來標記變量。
2、{% … %} 用來標記語句,比如 if 語句,for 語句等。
3、{# … #} 用來寫注釋。
模板中使用的變量需要在渲染的時候傳遞進去。
編寫主頁模板
我們先在 templates 目錄下創(chuàng)建一個 movie.html 文件,作為主頁模板。主頁需要顯示電影條目列表和個人信息,代碼如下所示:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>movie list</title> </head> <body> {# 使用 length 過濾器獲取 movies 變量的長度 #} <p>{{ movies|length }} Titles</p> <ul> {% for movie in movies %} {# 迭代 movies 變量 #} <li>{{ movie.title }} - {{ movie.year }}</li> {# 等同于 movie['title'] #} {% endfor %} {# 使用 endfor 標簽結(jié)束 for 語句 #} </ul> </body> </html>
為了方便對變量進行處理,Jinja2 提供了一些過濾器(和Vue.js框架中的過濾器有著異曲同工之妙),語法形式如下:
{{ 變量|過濾器 }}
左側(cè)是變量,右側(cè)是過濾器名。比如,上面的模板里使用 length 過濾器來獲取movies 的長度,類似 Python 里的 len() 函數(shù)。
準備虛擬數(shù)據(jù)
為了模擬頁面渲染,我們需要先創(chuàng)建一些虛擬數(shù)據(jù),用來填充頁面內(nèi)容,其中template.py中定義虛擬數(shù)據(jù)。
movies = [{'title': '長津湖', 'year': '2021'},{'title': '送你一朵小紅花', 'year': '2021'}]
渲染主頁模板
使用 render_template() 函數(shù)可以把模板渲染出來,必須傳入的參數(shù)為模板文件名(相對于 templates 根目錄的文件路徑),這里即 ‘movie.html' 。為了讓模板正確渲染,我們還要把模板內(nèi)部使用的變量通過關鍵字參數(shù)傳入這個函數(shù),如下所示:
from flask import Flask, render_template app = Flask(__name__) @app.route('/') def movie(): return render_template('movie.html', movies=movies) if __name__ == "__main__": app.run()
在傳入 render_template()
函數(shù)的關鍵字參數(shù)中,左邊的 movies 是模板中使用的變量名稱,右邊的movies 則是該變量指向的實際對象。這里傳入模板的movies 是列表,但能夠在模板里使用的不只這一種 Python數(shù)據(jù)結(jié)構,你也可以傳入字符串、元組、字典、函數(shù)等。
render_template()
函數(shù)在調(diào)用時會識別并執(zhí)行 “movie.html” 里所有的 Jinja2 語句,返回渲染好的模板內(nèi)容。在返回的頁面中,變量會被替換為實際的值(包括定界符),語句(及定界符)則會在執(zhí)行后被移除(注釋也會一并移除)。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內(nèi)容!
相關文章
Python?TypeError:?‘float‘?object?is?not?subscriptable錯
發(fā)現(xiàn)問題寫python的時候出現(xiàn)了這個錯,所以想著給大家總結(jié)下,這篇文章主要給大家介紹了關于Python?TypeError:?‘float‘?object?is?not?subscriptable錯誤的解決辦法,需要的朋友可以參考下2022-12-12Python使用Matplotlib實現(xiàn)創(chuàng)建動態(tài)圖形
動態(tài)圖形是使可視化更具吸引力和用戶吸引力的好方法,它幫助我們以有意義的方式展示數(shù)據(jù)可視化,本文將利用Matplotlib實現(xiàn)繪制一些常用動態(tài)圖形,希望對大家有所幫助2024-02-02Python中數(shù)組,列表:冒號的靈活用法介紹(np數(shù)組,列表倒序)
下面小編就為大家分享一篇Python中數(shù)組,列表:冒號的靈活用法介紹(np數(shù)組,列表倒序),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04利用Python通過獲取剪切板數(shù)據(jù)實現(xiàn)百度劃詞搜索功能
大家是不是嫌棄每次打開百度太麻煩?今天教大家利用Python通過獲取剪切板數(shù)據(jù)實現(xiàn)百度劃詞搜索功能,用程序直接打開網(wǎng)頁,需要的朋友可以參考下2021-06-06