制作一个模板二

即上面用于向浏览器传递HTML的解决方案并不好。考虑一下,当您添加来自用户的博客文章时,这个视图函数中的代码会变得多么复杂,因为这些博文会不断变化。该应用程序还将拥有更多与其他url相关联的视图函数,因此想象一下,如果有一天我决定更改该应用程序的布局,并且必须更新每个视图函数中的HTML。这显然不是一个可以随着应用程序的增长而扩展的选项。

如果你能把应用程序的逻辑与网页的布局或表现分开,那么事情就会组织得更好,你不觉得吗?你甚至可以雇佣一个网页设计师来创建一个杀手级网站,而你用Python编写应用程序逻辑。

模板有助于实现表示和业务逻辑之间的这种分离。在Flask中,模板是作为单独的文件编写的,存储在应用程序包内的模板文件夹中。因此,在确保您在微博目录中之后,创建将存储模板的目录:

app/templates/index.html:

复制代码
<!doctype html>
<html>
    <head>
        <title>{{ title }} - Microblog</title>
    </head>
    <body>
        <h1>Hello, {{ user.username }}!</h1>
    </body>
</html>

这是一个基本标准的、非常简单的HTML页面。在这个页面中唯一有趣的事情是有一对动态内容的占位符,包含在{{...}}部分。这些占位符表示页面中可变的部分,只有在运行时才会知道。

现在页面的表示已经被卸载到HTML模板中,view函数可以简化:

复制代码
from flask import render_template
from app import app

@app.route('/')
@app.route('/index')
def index():
    user = {'username': 'Miguel'}
    return render_template('index.html', title='Home', user=user)

这个看起来好多了,对吧?尝试这个新版本的应用程序,看看模板是如何工作的。在浏览器中加载页面后,您可能希望查看源HTML并将其与原始模板进行比较。

将模板转换为完整HTML页面的操作称为呈现。为了呈现模板,我必须导入一个Flask框架自带的函数render_template()。该函数接受一个模板文件名和一个模板参数变量列表,并返回相同的模板,但其中的所有占位符都被替换为实际值。

render_template()函数调用Flask框架附带的Jinja2模板引擎。jinj2替代{{...}}块使用相应的值,由render_template()调用中提供的参数给出。

相关推荐
databook1 分钟前
探索视觉的边界:用 Manim 重现有趣的知觉错觉
python·动效
明月_清风1 小时前
Python 性能微观世界:列表推导式 vs for 循环
后端·python
明月_清风1 小时前
Python 性能翻身仗:从 O(n) 到 O(1) 的工程实践
后端·python
helloweilei17 小时前
python 抽象基类
python
用户83562907805117 小时前
Python 实现 PPT 转 HTML
后端·python
zone77391 天前
004:RAG 入门-LangChain读取PDF
后端·python·面试
zone77391 天前
005:RAG 入门-LangChain读取表格数据
后端·python·agent
树獭非懒2 天前
AI大模型小白手册|Embedding 与向量数据库
后端·python·llm
唐叔在学习2 天前
就算没有服务器,我照样能够同步数据
后端·python·程序员
曲幽2 天前
FastAPI流式输出实战与避坑指南:让AI像人一样“边想边说”
python·ai·fastapi·web·stream·chat·async·generator·ollama