本文实例总结了Flask框架Jinjia模板常用语法。分享给大家供大家参考,具体如下:
1. 变量表示
{{ argv }}
2. 赋值操作
{% set links = [ ('home',url_for('.home')), ('service',url_for('.service')), ('about',url_for('.about')),] %}
3. if判断
{% if not loop.first %}|{% endif %}
4. for 循环
{% for label,link in links %} {% if not loop.first %}|{% endif %} <a href="{{ link }}" rel="external nofollow" >{{ label }}</a>{% endfor %}
5. 定义测试函数
上面 loop.first
就是一个测试函数,这个我们也可以自定义
定义是在Sample.py 里定义的,current_link
是HTML中可使用测试函数名称(可选)
@app.template_test('current_link')def is_current_link(link): return link == request.path
HTML中,使用例子
<body>{% set links = [ ('home',url_for('.home')), ('service',url_for('.service')), ('about',url_for('.about')),] %}<nav> {% for label,link in links %} {% if not loop.first %}|{% endif %} <a href="{% if link is current_link %}# {% else %} {{ link }} {% endif %} ">{{ label }}</a> {% endfor %}</nav></body>
6. 块block
Flask强大的地方就可以引用模板,而且非常方便。
这里不得不介绍block这个概念。
模板的文件一般放在templates文件夹下,我们这里新建一个HTML文件,存放模板,'base.html'
在这里面也,编排了整个页面的排版,里面会用到很多block的占位符。
每个block都代表一段html语句块,而这些块在哪里定义呢,可以在当前的base.html中定义,也可以在别的html中定义。反正要有一处定义,没有定义块只是没有效果而已
定义的时候,home.html 顶部必须说明继承关系(如果py文件链接的是home.html,但home.html引用了base.html的模板,就要说明)
{% extends 'base.html' %}
块的定义格式,endblock 后面块名可以省略,有时候加上会让结构更加明晰
{% block 块名 %} 块内容{% endblock (块名)%}
定义了块之后,base.html中对应的块,就会被这些块内容覆盖。
块的覆盖情况
有一种情况,base.html中定义了block B 块内容1,但是在home.html也定义block B 块内容2,注意这时会优先显示内容2,因为把内容1覆盖了。
理解起来,就是base.html是通用模板,我们可以直接引用过来,没有问题,但是也可以自定义块,修改通用模板的内容,达到我们想要的效果。
还有一种情况,我们既不想不覆盖通用模板的内容,又想在其基础上,增加一些东西,这也是可以的。
新闻热点
疑难解答