Jinja2如何实现模板渲染与访问对象属性

发布时间:2023-03-09 14:25:53 作者:iii
来源:亿速云 阅读:277

这篇“Jinja2如何实现模板渲染与访问对象属性”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Jinja2如何实现模板渲染与访问对象属性”文章吧。

1.Jinja2

1.简介

Jinja2是Python下一个被广泛应用的模版引擎,他的设计思想来源于Django的模板引擎,并扩展了其语法和一系列强大的功能。其中最显著的一个是增加了沙箱执行功能和可选的自动转义功能,这对大多应用的安全性来说是非常重要的。

2.Jinja2模板

Jinja 模板只是一个文本文件,可以 基于模板生成任何基于文本的格式(HTML、XML、CSV、LaTeX 等),一般用在前端的项目中,渲染 HTML 文件。

作为网络工程师,可以将其用来批量生成网络设备的配置或者其他需要批量生成文本的场景中。

模板包含变量或表达式,这两者在模板求值的时候会被替换为值。模板中还有标签,控制模板的逻辑。模板语法的大量灵感来自于 Django 和 Python 。

2.模板渲染

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>
<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>

效果

Jinja2如何实现模板渲染与访问对象属性

Jinja2如何实现模板渲染与访问对象属性

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>
<h2>小程困了</h2>
<div>{{ user.username }} / {{ user.email }}</div>
<div>{{ person['username'] }} / {{ person.email }}</div>
</body>
</html>

效果

Jinja2如何实现模板渲染与访问对象属性

以上就是关于“Jinja2如何实现模板渲染与访问对象属性”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。

推荐阅读:
  1. django如何自定义jinja2的tag与filter
  2. Jinja2 简明使用手册

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

jinja2

上一篇:Node.contain函数兼容处理的方法是什么

下一篇:C语言执行程序时遇到的常见问题如何解决

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》