制作一个模板二

news/2024/7/8 3:11:44 标签: python

即上面用于向浏览器传递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()调用中提供的参数给出。


http://www.niftyadmin.cn/n/5164636.html

相关文章

flutter生态一统甜夏 @Android @ios @windowse @macos @linux @Web

(愿景)G o o g l e 中 国flutter生态一统天下(IT) Web Android ios Windowse Macos Linux Google中国https://space.bilibili.com/64169458 https://pub-web.flutter-io.cn 构建 Flutter Web 应用 构建 Flutter Web 应用 - Flutter 中文文档 - Flutter 中文开发者网站 …

安卓常见设计模式7------适配器模式(Kotlin版)(RecycleView adapter 模板代码)

1. W1 是什么&#xff0c;什么是适配器模式&#xff1f;​ 适配器模式&#xff08;Adapter Pattern&#xff09;是一种常见的设计模式&#xff0c;它用于将一个类的接口转换成另一个客户端所期望的接口。在 Android 中&#xff0c;适配器模式通常用于将数据与视图进行绑定&…

【ArcGIS Pro二次开发】(75):ArcGIS Pro SDK二次开发中的常见问题及解决方法

ArcGIS Pro SDK二次开发路程也近一年时间了&#xff0c;这里总结一下平时遇到的一些问题和解决方法。有些问题没能解决&#xff0c;也记录下来&#xff0c;提醒自己不要忘记。 一、在VS2022中进行调试弹出错误 正常在VS2022中&#xff0c;如果要调试程序的话&#xff0c;直接按…

DHCP概述及原理

• Dynamic Host Configuration Protocol – 动态主机配置协议,由 IETF(Internet 网络工程师任 务小组)组织制定, 用来简化主机地址分配管理 • 主要分配以下入网参数 – IP地址/子网掩码/广播地址 – 默认网关地址、DNS服务器地址 DHCP概述及原理&#xff08;广播进行&a…

grpc使用教程

准备 1&#xff0c;安装grpc go get -u google.golang.org/grpc2, 安装go语言protobuf生成器protoc-gen-go go get -u google.golang.org/protobuf/cmd/protoc-gen-go注意&#xff1a; 将GOPATH下的bin目录配置在环境变量中否则会找不到命令编写proto文件 # server/proto/tes…

Globalsign证书

GlobalSign是全球可信的数字证书提供商之一&#xff0c;提供广泛的证书服务&#xff0c;包括SSL证书、代码签名证书、电子邮件证书等&#xff0c;帮助保护企业和个人的网络安全。本文将详细介绍GlobalSign证书的特点和优势&#xff0c;帮助您更好地了解这一重要的数字证书提供商…

重装系统后,如何恢复丢失的桌面文件

在我们使用电脑的过程中&#xff0c;有时不得不重装操作系统&#xff0c;以解决各种问题和提升电脑性能。然而&#xff0c;重装系统后会遇到一个常见的问题&#xff0c;那就是丢失了桌面上的文件和文件夹。这些文件可能是用户的个人数据、重要的工作文档或珍贵的照片&#xff0…

swift和OC混编报错问题

1.‘objc’ instance method in extension of subclass of ‘xxx’ requires iOS 13.0.0 需要把实现从扩展移到主类实现。iOS13一下扩展不支持objc 2.using bridging headers with framework targets is unsupported 报错 这个错误通常指的是在一个框架目标中使用桥接头是不…