Flask使用Jinja2渲染模版使用变量实战

前言:

Flask 使用 Jinja2 作为其默认模板引擎,这意味着您可以直接在 Flask 应用程序中使用 Jinja2 模板。您可以创建模板文件,然后在视图函数中渲染这些模板,将动态数据传递给模板进行渲染,并最终生成最终的 HTML 页面。

一、传递变量到Jinja2

app.py

python 复制代码
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 index():
    hobby = "游戏"
    person = {
        "name": "张三",
        "age": 181
    }
    user = User("李四", "xx@qq.com")
    return render_template("index.html", hobby=hobby, person=person, user=user)


if __name__ == '__main__':
    app.run(debug=True)

index.html

python 复制代码
    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <title>变量使用</title>
    </head>
    <body>
      <h1>我的兴趣爱好是:{{ hobby }}</h1>
      <p>person的姓名是:{{ person.name }},person的年龄是:{{ person.age }}</p>
      <p>user的用户名是:{{ user.name }},user的邮箱是:{{ user.email }}</p>
    </body>
    </html>

运行项目效果

PS:字典健和对象的属性也可以通过中括号的方式来获取,如下面这样获取

python 复制代码
{{ user.name }}
{{ user['name'}}

二、使用关键字参数方式传递

以上案例中,传递了3个变量到模版中,在变量较多的情况下,首先可以把所有的变量放到字典中,然后再给render_template传递参数时使用**语法,将字典变成关键字参数,以上的视图函数可以修改为下面的形式:

python 复制代码
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 index():
    hobby = "游戏"
    person = {
        "name": "张三",
        "age": 18
    }
    user = User("李四", "xx@qq.com")
    context = {
        "hobby": hobby,
        "person": person,
        "user": user
    }
    return render_template("index.html", **context)


if __name__ == '__main__':
    app.run(debug=True)

最后执行效果其实是一样的

相关推荐
夕除1 分钟前
Spring Security 配置类(SecurityConfig)
java·后端·spring
lfwh2 分钟前
探针程序技术解析:基于 Spring Boot 非 Web 模式的云服务监控告警系统
前端·spring boot·后端
cd988803 分钟前
2026年,电销机器人哪家技术强?
python
weixin199701080164 分钟前
[特殊字符] 1688开放平台API Sign签名算法详解(Java / Python / PHP 实现)
java·python·算法
武子康8 分钟前
Java-22 深入浅出 MyBatis - 手写ORM框架3 手写SqlSession、Executor 工作原理
java·后端
ikoala18 分钟前
Codex 不得不装的 12 个插件,都在这了
前端·javascript·后端
TickDB30 分钟前
Python 调用实时行情 API:ticker 返回成功后,如何校验字段再入库或展示
python·websocket·行情数据 api
摇滚侠32 分钟前
SpringMVC 入门到实战 简介和入门案例 01-13
java·后端·spring·intellij-idea
蝎子莱莱爱打怪33 分钟前
自用推荐|XTerminal:我心中 SSH 客户端的终极形态
java·后端·程序员
AC赳赳老秦37 分钟前
OpenClaw 助力技术面试:自动生成面试题、模拟面试、整理面试知识点
开发语言·python·面试·职场和发展·自动化·deepseek·openclaw