flask中jinjia2模板引擎使用详解2

接上文

注释的使用

在jinjia2模板中,使用{# #}进行代码注释,如下所示

运行后发现,注释不会被render出来

去掉空行

两种方法可以去掉jinjia2模板中的空白行,一是设置jinjia2的环境变量,如下

app.jinja_env.trim_blocks= True

app.jinja_env.lstrip_blocks = True

另一种是通过在模板的逻辑块中添加-号

{% if name -%}

  <h1>Hello {{ name | upper }}!h1>

    <h1>name is number? {% if name is number %}true{% else  %}false{% endif %}h1>

{# 这是一大堆注释#}{%- else -%}

  <h1>Hello World!h1>

{%endif %}

-在前面说明要除去前面的空行,在后面除去后面的空行,两边都加前后都去掉空白行。

注:-是标签的一部分,所以中间不要有空格

下面这种表达是不合法的:

{% - if xxx %}

转义

想要在模板中输出原生jinjia2语法,需要进行转义,转义有两种方法

一种是通过变量表达式直接输出语言关键字,比如

{{ "{{ 通过转义输出变量表达式 }}" }}

{{"{%  通过转义输出逻辑表达式 %}" }} 

转出效果:

另一种是通过raw关键字进行大块转义

{% raw %}

    <ul>

    {% for item in seq %}

        <li>{{ item }}li>

    {% endfor %}

    </ul>

{% endraw %}

运行效果:

行语句

行语句就是把一行当成是jinjia2的语句行,设置一下jinjia2的line_statement_prefix变量即可实现。比如设置为“#”

app.jinja_env.line_statement_prefix="#"

同时在模板中加入行语句

# if True

<p>行语句输出p>

# endif

运行效果:

行注释 

通过设置line_comment_prefix可以实现行注释,步骤跟行语句一样,比如,我们设置:

app.jinja_env.line_comment_prefix = "$"

在模板中加入注释

$行注释,不输出

运行后,查看源码,发现注释没有被输出

 关注“挨踢学霸”微信公众号,回复“jinjia2-2“ 获取本文源代码

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 介绍 Jinja是基于python的模板引擎,功能比较类似于于PHP的smarty,J2ee的Freemarker...
    ZhouLang阅读 8,290评论 0 2
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,695评论 19 139
  • Lua 5.1 参考手册 by Roberto Ierusalimschy, Luiz Henrique de F...
    苏黎九歌阅读 14,264评论 0 38
  • 模板是一个包含响应文本的文件,其中包含用占位变量表示的动态部分,其具体值只在请求的上下文中才能知道。使用真实值替换...
    藕丝空间阅读 1,363评论 0 1
  • 001 文艺复兴意大利“小三杰” 弗朗切斯卡、曼泰尼亚、乌切洛,他们的绝活为文艺复兴大三杰奠定了坚实的基础。...
    路上的幸福_影阅读 312评论 0 1

友情链接更多精彩内容