Jinja2实现模板渲染与访问对象属性流程详解
作者:头秃小程 时间:2022-09-18 14:44:20
1.Jinja2
1.简介
Jinja2是Python下一个被广泛应用的模版引擎,他的设计思想来源于Django的模板引擎,并扩展了其语法和一系列强大的功能。其中最显著的一个是增加了沙箱执行功能和可选的自动转义功能,这对大多应用的安全性来说是非常重要的。
2.Jinja2模板
Jinja 模板只是一个文本文件,可以 基于模板生成任何基于文本的格式(HTML、XML、CSV、LaTeX 等),一般用在前端的项目中,渲染 HTML 文件。
作为网络工程师,可以将其用来批量生成网络设备的配置或者其他需要批量生成文本的场景中。
模板包含变量或表达式,这两者在模板求值的时候会被替换为值。模板中还有标签,控制模板的逻辑。模板语法的大量灵感来自于 Django 和 Python 。
2.模板渲染
创建和渲染模板的最基本方法是通过
Template
,通过创建一个Template
的实例Flask提供的render_template 函数封装了Jinja2模板引擎
render_template 函数的第一个参数是模板的文件名,后面的参数都是键值对,表示向模板中传递的参数值
app.py
# render_template 渲染模板
from flask import Flask,render_template
app = Flask(__name__)
@app.route('/')
def hello_world(): # put application's code here
return render_template("index.html")
@app.route("/blog/<blog_id>")
def blog_detail(blog_id):
return render_template("blog_detail.html",blog_id=blog_id,username="小程")
if __name__ == '__main__':
app.run()
templates/index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>小程困了</h1>
</body>
</html>
templates/blog_detail.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>博客详情</title>
</head>
<body>
<p>您的用户名是:{{ username }}</p>
<h1>您访问的博客详情是:{{ blog_id }}</h1>
</body>
</html>
效果
3.模板访问对象属性
app.py
# render_template 渲染模板
from flask import Flask, render_template
app = Flask(__name__)
class User:
def __init__(self, username, email):
self.username = username
self.email = email
@app.route('/')
def hello_world(): # put application's code here
user = User(username="小程", email="xxx@qq.com")
person = {
"username": "张三",
"email": "zhangsan@qq.com"
}
return render_template("index.html", user=user, person=person)
@app.route("/blog/<blog_id>")
def blog_detail(blog_id):
return render_template("blog_detail.html", blog_id=blog_id, username="小程")
if __name__ == '__main__':
app.run()
templates/index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>小程困了</h1>
<div>{{ user.username }} / {{ user.email }}</div>
<div>{{ person['username'] }} / {{ person.email }}</div>
</body>
</html>
效果
来源:https://blog.csdn.net/Maruko_428/article/details/129229622
标签:Jinja2,模板渲染,访问对象属性
0
投稿
猜你喜欢
python机器学习实战之树回归详解
2022-02-05 04:37:10
python 图片验证码代码分享
2022-02-21 17:10:27
Python实现简单拆分PDF文件的方法
2022-09-27 19:20:37
Win中安装mysql的详细步骤
2024-01-15 18:38:19
python实现自动解数独小程序
2023-03-28 12:15:19
Golang实现WebSocket服务的项目实践
2024-04-28 09:15:51
SQL Server 2012 开窗函数
2024-01-28 01:39:15
一文让你彻底搞懂Python中__str__和__repr__
2021-10-30 20:09:56
Python 控制终端输出文字的实例
2021-10-23 21:30:56
python利用JMeter测试Tornado的多线程
2022-10-15 12:03:26
使用Python编写Linux系统守护进程实例
2022-06-09 16:50:52
使用PyCharm调试程序实现过程
2023-09-30 10:27:08
聊聊Python中关于a=[[]]*3的反思
2021-09-08 05:12:46
python画图系列之个性化显示x轴区段文字的实例
2023-01-16 06:15:24
表单验证中时间起止判断的递归处理
2009-12-16 19:27:00
Python如何使用ElementTree解析xml
2023-02-05 07:22:06
ASP+ajax注册即时提示程序代码
2011-02-05 11:25:00
python 第三方库的安装及pip的使用详解
2023-12-27 07:06:53
python3 pandas 读取MySQL数据和插入的实例
2024-01-22 06:21:33
看看如何用Python绘制小米新版天价logo
2023-04-09 06:01:10