{% raw %}

Flask 教程:模板

原文: https://pythonbasics.org/Flask-Tutorial-Templates/

模板可帮助您重用视觉效果。 在所有 Web 应用程序中,视觉效果都可以重复使用。 这可以帮助您划分业务和表示逻辑。 您不希望您的应用程序代码与图形设计代码混合在一起。

想象一下一个分析应用程序。 您希望每个页面上都有相同的导航和页脚。 内容可能有所不同,但总体设计保持不变。 这是通过模板完成的。

模板示例

您要做的第一件事是为模板创建目录。 您可以使用以下命令从终端执行此操作。 如果尚未这样做,请创建一个应用。 假设您的项目目录名为app

  1. (venv) $ mkdir app/templates

单个模板只是一个文件。 每个模板都包含 HTML 代码,这是 Web 的标准语言。

Flask 模板变量

让我们创建文件index.html

  1. <html>
  2. <head>
  3. <title>{{ title }}</title>
  4. </head>
  5. <body>
  6. <h1>Hello {{ username }}</h1>
  7. </body>
  8. </html>

其中大多数是 HTML 标记(在<>符号之间),这是网络上的标准标记。

那么,那些 {{}} 符号是什么?

这是在网页上显示 Python 变量的方式。 它们是要显示的变量的占位符。

在此模板中,可以传递两个变量:标题和用户名。

模板渲染

要知道的关键事情之一是,模板用于将业务逻辑与表示逻辑分开。 这样可以提高软件的可维护性,可扩展性和可移植性。

可以从您的 Python 代码中传递变量。 Python 需要渲染模板,因此需要导入模板。

  1. from flask import render_template

更改原始代码:

  1. @app.route('/')
  2. def index():
  3. return 'Web App with Python Flask!'

进入渲染模板并传递变量的代码:

  1. @app.route('/')
  2. @app.route('/index')
  3. def index():
  4. name = 'Rosalia'
  5. return render_template('index.html', title='Welcome', username=name)

然后启动应用程序:

  1. sudo python3 app.py

然后它将在终端中显示一些文本:

  1. * Serving Flask app "app" (lazy loading)
  2. * Environment: production
  3. WARNING: This is a development server. Do not use it in a production deployment.
  4. Use a production WSGI server instead.
  5. * Debug mode: off
  6. * Running on http://0.0.0.0:81/ (Press CTRL+C to quit)

并在 Web 浏览器中打开终端中显示的 URL。

render_template

在上面的示例中,您调用了函数render_template()。 为什么要调用此方法而不立即返回 html 数据?

Flask 与一种名为 Jinja2 的语言捆绑在一起。 这使您能够直接在模板中包含变量,创建循环和添加if语句。

在上面的示例中,您已经了解了如何包含titleusername之类的变量。 那么,如何包含循环和if语句?

153.md - 图1

Flask 模板if

您可以在模板中包含if语句。 可以使用与 Python 中相同的运算符(==><>=<=)。 也可以使用elseelif之类的子句。

在此代码中,输出将根据输入变量用户名而有所不同。 用户名通过 Python 代码(业务逻辑)传递到模板(表示逻辑)。

  1. <html>
  2. <head>
  3. <title>{{ title }}</title>
  4. </head>
  5. <body>
  6. {% if username == "Rosalia": %}
  7. <h1>Hello my love</h1>
  8. {% else %}
  9. <h1>Hello {{ username }}</h1>
  10. {% endif %}
  11. </body>
  12. </html>

Flask 模板for循环

如果您有大量数据(例如用户列表),则希望使用for循环对其进行迭代。 将 Python 代码更改为此:

  1. @app.route('/')
  2. @app.route('/index')
  3. def index():
  4. users = [ 'Rosalia','Adrianna','Victoria' ]
  5. return render_template('index.html', title='Welcome', members=users)

该代码包括一个列表(用户)。 该列表将传递给render_template函数。 在模板中,可以使用for循环遍历列表。

  1. <html>
  2. <head>
  3. <title>{{ title }}</title>
  4. </head>
  5. <body>
  6. <ul>
  7. {% for member in members: %}
  8. <li>{{ member }}</li>
  9. {% endfor %}
  10. </ul>
  11. </body>
  12. </html>

对于代码,使用标签 {%%}
要显示变量,请写入标签 {{}}

153.md - 图2

下载示例

{% endraw %}