Flask之Jinja2模板

Jinja2模板

Fkask中的页面渲染是通过jinjia2模块实现的,依赖于render_template函数
默认在template文件路径下

模板传参

(1)如果只有一个或者少量参数,直接在render_template函数中添加关键字参数就可以了。

使用格式:
		return render_template('模板文件',key=value)

(2)如果有多个参数的时候,那么可以先把所有的参数放在字典中,然后在render_template中, 使用两个星号,把字典转换成关键参数传递进去,这样的代码更方便管理和使用。

    context = {
   
        'username' : '站长',
        'age' : '18',
        'gender' : '男'
    }
     # 定义一个字典,双星号把字典转换成关键参数传递进去
    return render_template('index.html' , **context)

常见语法

模版讲解:

  • { { … }}:装载一个变量,模板渲染的时候,会使用传进来的同名参数这个变量代表的值替换掉。
  • {% … %}:装载一个控制语句。
  • {# … #}:装载一个注释,模板渲染的时候会忽视这中间的值。
常见语法:
	获取变量:
		{
  {变量}}
		分支语句:
			{% if 条件A %}
				语句1
			{% elif 条件B %}
				语句2
			{%endif%}
			执行流程:
				那个条件为True,执行哪个语句
				顺序判断


			循环语句:
				{% for 变量 in 容器 %}
				{%endfor%}

Jinja2中for循环内置常量

  • loop.index 当前迭代的索引(从1开始)
  • loop.index0 当前迭代的索引(从0开始)
  • loop.first 是否是第一次迭代,返回True/False
  • loop.last 是否是最后一次迭代,返回True/False
  • loop.length 序列的长度

具体使用

html文件内容:用了条件判断和循环

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    {% if title %}
    <title>{
  { title }}</title>
    {% else %}
    <title>这是默认标题</title>
    {% endif %}
</head>
<body>
<h1>{
  { user.name }}</h1>
{% for news in news_list %}
<p>{
  { news.author }} say:</p><p>{
  { news.article }}</p>
{% endfor %}
{# 字典遍历 #}
{% for k,v in user.items() %}
    <p>{
  { k }}:{
  { v }}</p>
{% endfor %}
</body>
</html>

视图函数:

@app.route('/ind
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值