内容简介:创建一个模板文件app/templates/index.html,内容如下jinja2模板引擎使用{{….}} 来获取视图函数传来的变量在视图函数中渲染模板app/views.py,内容如下
创建一个模板文件app/templates/index.html,内容如下
jinja2模板引擎使用{{….}} 来获取视图函数传来的变量
<html> <head> <title>{{title}} - blog</title> </head> <body> <h1>Hello, {{user.nickname}}!</h1> </body> </html>
在视图函数中渲染模板app/views.py,内容如下
render_template是渲染模板,第一个参数是需要渲染的模板文件,模板文件默认是app目录下的templates目录,要对模板传入flask的变量通过关键字参数的方式传入
from flask import render_template from app import app @app.route('/') @app.route('/index') def index(): user = { 'nickname': 'zdz' } # fake user return render_template("index.html", title = 'Home',user = user)
在模板中使用控制语句,控制语句写在 {% …. %} 中,修改app/templates/index.html,内容如下
<html> <head> {% if title %} <title>{{title}} - blog</title> {% else %} <title>Welcome to blog</title> {% endif %} </head> <body> <h1>Hello, {{user.nickname}}!</h1> </body> </html>
修改视图函数app/views.py,内容如下
def index(): user = { 'nickname': 'zdz' } posts = [ { 'author': { 'nickname': '张三' }, 'body': '张三' }, { 'author': { 'nickname': '李四' }, 'body': '李四' } ] return render_template("index.html", title = 'Home', user = user, posts = posts)
在模板中使用循环语句,视图函数将posts这个变量作为列表传入模板,模板可以使用字典或者对象的方式获取传入的变量的值。
<html> <head> {% if title %} <title>{{title}} - blog</title> {% else %} <title>blog</title> {% endif %} </head> <body> <h1>Hi, {{user.nickname}}!</h1> {% for post in posts %} <p>{{post.author.nickname}} says: <b>{{post.body}}</b></p> {% endfor %} </body> </html>
以上所述就是小编给大家介绍的《flask中使用模板》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Helm 命名模板的使用
- ThinkPHP模板范围判断标签使用
- 使用函数式编程重构模板模式
- React与Vue模板使用比较(一、vue模板与React JSX比较)
- 10 - 页面侧边栏:使用自定义模板标签
- 10 - 页面侧边栏:使用自定义模板标签
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。