flask中使用模板

栏目: Python · 发布时间: 5年前

内容简介:创建一个模板文件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中使用模板》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

锋利的jQuery

锋利的jQuery

单东林、张晓菲、魏然 / 人民邮电出版社 / 2009-6 / 39.00元

《锋利的jQuery》循序渐进地对jQuery的各种函数和方法调用进行了介绍,读者可以系统地掌握jQuery的DOM操作、事件监听和动画、表单操作、AJAX以及插件方面等知识点,并结合每个章节后面的案例演示进行练习,达到掌握核心知识点的目的。为使读者更好地进行开发实践,《锋利的jQuery》的最后一章将前7章讲解的知识点和效果进行了整合,打造出一个非常有个性的网站,并从案例研究、网站材料、网站结构......一起来看看 《锋利的jQuery》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具