内容简介:创建一个模板文件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 - 页面侧边栏:使用自定义模板标签
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
智能优化算法及其应用
王凌 / 清华大学出版社 / 2001-10 / 22.00元
智能优化算法及其应用,ISBN:9787302044994,作者:王凌著一起来看看 《智能优化算法及其应用》 这本书的介绍吧!