Jinja2如何实现模板渲染与访问对象属性
这篇“Jinja2如何实现模板渲染与访问对象属性”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Jinja2如何实现模板渲染与访问对象属性”文章吧。
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_templateapp = 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><h2>小程困了</h2></body></html>
templates/blog_detail.html
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>博客详情</title></head><body><p>您的用户名是:{{ username }}</p><h2>您访问的博客详情是:{{ blog_id }}</h2></body></html>
效果
3.模板访问对象属性
app.py
# render_template 渲染模板from flask import Flask, render_templateapp = 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><h2>小程困了</h2><div>{{ user.username }} / {{ user.email }}</div><div>{{ person['username'] }} / {{ person.email }}</div></body></html>
效果
以上就是关于“Jinja2如何实现模板渲染与访问对象属性”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341