{% raw %}
# Flask 教程:模板
> 原文: [https://pythonbasics.org/Flask-Tutorial-Templates/](https://pythonbasics.org/Flask-Tutorial-Templates/)
模板可帮助您重用视觉效果。 在所有 Web 应用程序中,视觉效果都可以重复使用。 这可以帮助您划分业务和表示逻辑。 您不希望您的应用程序代码与图形设计代码混合在一起。
想象一下一个分析应用程序。 您希望每个页面上都有相同的导航和页脚。 内容可能有所不同,但总体设计保持不变。 这是通过模板完成的。
## 模板示例
您要做的第一件事是为模板创建目录。 您可以使用以下命令从终端执行此操作。 如果尚未这样做,请[创建一个应用](https://pythonbasics.org/Flask-Tutorial-Hello-World/)。 假设您的项目目录名为`app`,
```py
(venv) $ mkdir app/templates
```
单个模板只是一个文件。 每个模板都包含 HTML 代码,这是 Web 的标准语言。
### Flask 模板变量
让我们创建文件`index.html`
```py
<html>
<head>
<title>{{ title }}</title>
</head>
<body>
<h1>Hello {{ username }}</h1>
</body>
</html>
```
其中大多数是 HTML 标记(在`<`和`>`符号之间),这是网络上的标准标记。
那么,那些 `{{` 和 `}}` 符号是什么?
这是在网页上显示 Python 变量的方式。 它们是要显示的变量的占位符。
在此模板中,可以传递两个变量:标题和用户名。
## 模板渲染
要知道的关键事情之一是,模板用于将业务逻辑与表示逻辑分开。 这样可以提高软件的可维护性,可扩展性和可移植性。
可以从您的 Python 代码中传递变量。 Python 需要渲染模板,因此需要导入模板。
```py
from flask import render_template
```
更改原始代码:
```py
@app.route('/')
def index():
return 'Web App with Python Flask!'
```
进入渲染模板并传递变量的代码:
```py
@app.route('/')
@app.route('/index')
def index():
name = 'Rosalia'
return render_template('index.html', title='Welcome', username=name)
```
然后启动应用程序:
```py
sudo python3 app.py
```
然后它将在终端中显示一些文本:
```py
* Serving Flask app "app" (lazy loading)
* Environment: production
WARNING: This is a development server. Do not use it in a production deployment.
Use a production WSGI server instead.
* Debug mode: off
* Running on http://0.0.0.0:81/ (Press CTRL+C to quit)
```
并在 Web 浏览器中打开终端中显示的 URL。
## `render_template`
在上面的示例中,您调用了函数`render_template()`。 为什么要调用此方法而不立即返回 html 数据?
Flask 与一种名为 [Jinja2](https://palletsprojects.com/p/jinja/) 的语言捆绑在一起。 这使您能够直接在模板中包含变量,创建循环和添加`if`语句。
在上面的示例中,您已经了解了如何包含`title`和`username`之类的变量。 那么,如何包含循环和`if`语句?
![jinja flask template engine](https://img.kancloud.cn/96/f4/96f4b5685cf6885fb1a7a5797db15381_831x168.jpg)
## Flask 模板`if`
您可以在模板中包含`if`语句。 可以使用与 Python 中相同的运算符(`==`,`>`,`<`,`>=`,`<=`)。 也可以使用`else`或`elif`之类的子句。
在此代码中,输出将根据输入变量用户名而有所不同。 用户名通过 Python 代码(业务逻辑)传递到模板(表示逻辑)。
```py
<html>
<head>
<title>{{ title }}</title>
</head>
<body>
{% if username == "Rosalia": %}
<h1>Hello my love</h1>
{% else %}
<h1>Hello {{ username }}</h1>
{% endif %}
</body>
</html>
```
## Flask 模板`for`循环
如果您有大量数据(例如用户列表),则希望使用`for`循环对其进行迭代。 将 Python 代码更改为此:
```py
@app.route('/')
@app.route('/index')
def index():
users = [ 'Rosalia','Adrianna','Victoria' ]
return render_template('index.html', title='Welcome', members=users)
```
该代码包括一个列表(用户)。 该列表将传递给`render_template`函数。 在模板中,可以使用`for`循环遍历列表。
```py
<html>
<head>
<title>{{ title }}</title>
</head>
<body>
<ul>
{% for member in members: %}
<li>{{ member }}</li>
{% endfor %}
</ul>
</body>
</html>
```
对于代码,使用标签 `{%` 和 `%}` 。
要显示变量,请写入标签 `{{` 和 `}}` 。
![for loop in jinja2](https://img.kancloud.cn/96/52/96528bd7b0d3c111e8f26e8f38739374_514x275.jpg)
[**下载示例**](https://gum.co/IMzBy)
{% endraw %}
- 介绍
- 学习 python 的 7 个理由
- 为什么 Python 很棒
- 学习 Python
- 入门
- 执行 Python 脚本
- 变量
- 字符串
- 字符串替换
- 字符串连接
- 字符串查找
- 分割
- 随机数
- 键盘输入
- 控制结构
- if语句
- for循环
- while循环
- 数据与操作
- 函数
- 列表
- 列表操作
- 排序列表
- range函数
- 字典
- 读取文件
- 写入文件
- 嵌套循环
- 切片
- 多个返回值
- 作用域
- 时间和日期
- try except
- 如何使用pip和 pypi
- 面向对象
- 类
- 构造函数
- 获取器和设置器
- 模块
- 继承
- 静态方法
- 可迭代对象
- Python 类方法
- 多重继承
- 高级
- 虚拟环境
- 枚举
- Pickle
- 正则表达式
- JSON 和 python
- python 读取 json 文件
- 装饰器
- 网络服务器
- 音频
- 用 Python 播放声音
- python 文字转语音
- 将 MP3 转换为 WAV
- 转录音频
- Tkinter
- Tkinter
- Tkinter 按钮
- Tkinter 菜单
- Tkinter 标签
- Tkinter 图片
- Tkinter 画布
- Tkinter 复选框
- Tkinter 输入框
- Tkinter 文件对话框
- Tkinter 框架
- Tkinter 列表框
- Tkinter 消息框
- Tkinter 单选按钮
- Tkinter 刻度
- 绘图
- Matplotlib 条形图
- Matplotlib 折线图
- Seaborn 分布图
- Seaborn 绘图
- Seaborn 箱形图
- Seaborn 热力图
- Seaborn 直线图
- Seaborn 成对图
- Seaborn 调色板
- Seaborn Pandas
- Seaborn 散点图
- Plotly
- PyQt
- PyQt
- 安装 PyQt
- PyQt Hello World
- PyQt 按钮
- PyQt QMessageBox
- PyQt 网格
- QLineEdit
- PyQT QPixmap
- PyQt 组合框
- QCheckBox
- QSlider
- 进度条
- PyQt 表格
- QVBoxLayout
- PyQt 样式
- 编译 PyQt 到 EXE
- QDial
- QCheckBox
- PyQt 单选按钮
- PyQt 分组框
- PyQt 工具提示
- PyQt 工具箱
- PyQt 工具栏
- PyQt 菜单栏
- PyQt 标签小部件
- PyQt 自动补全
- PyQt 列表框
- PyQt 输入对话框
- Qt Designer Python
- 机器学习
- 数据科学
- 如何从机器学习和 AI 认真地起步
- 为什么要使用 Python 进行机器学习?
- 机器学习库
- 什么是机器学习?
- 区分机器学习,深度学习和 AI?
- 机器学习
- 机器学习算法比较
- 为什么要使用 Scikit-Learn?
- 如何在 Python 中加载机器学习数据
- 机器学习分类器
- 机器学习回归
- Python 中的多项式回归
- 决策树
- k 最近邻
- 训练测试拆分
- 人脸检测
- 如何为 scikit-learn 机器学习准备数据
- Selenium
- Selenium 浏览器
- Selenium Cookie
- Selenium 执行 JavaScript
- Selenium 按 ID 查找元素
- Selenium 无头 Firefox
- Selenium Firefox
- Selenium 获取 HTML
- Selenium 键盘
- Selenium 最大化
- Selenium 截图
- Selenium 向下滚动
- Selenium 切换到窗口
- Selenium 等待页面加载
- Flask 教程
- Flask 教程:Hello World
- Flask 教程:模板
- Flask 教程:路由