Python语言-Jinja2用法
小标 2018-11-14 来源 : 阅读 1841 评论 0

摘要:本文主要向大家介绍了Python语言-Jinja2用法,通过具体的内容向大家展示,希望对大家学习Python语言有所帮助。

本文主要向大家介绍了Python语言-Jinja2用法,通过具体的内容向大家展示,希望对大家学习Python语言有所帮助。

一:渲染模版要渲染一个模板,通过render_template方法即可。@app.route('/about/')def about():return render_template('about.html',**{'user':'username'})渲染模版时有两种传递参数的方式:用 var='value' 传递一个参数;使用字典组织多个参数,并且加两个*号转换成关键字参数传入。python文件调用模板进行渲染的基本使用方法如下:from jinja2 import loaders, FileSystemLoader, Environment指定模板文件搜索的开始位置TemplateLoader = FileSystemLoader(searchpath="./", encoding='utf-8')TemplateEnv = Environment(loader=TemplateLoader)这里的文件位置是以searchpath作为基准的,而不是当前文件夹.template = TemplateEnv.get_template("./test.html")html = template.render({"config": config})需要注意的是:如果传到模板文件的变量config是一个列表(字典)等容器类型;当config作为整体被使用时,渲染之后不会进行decode,造成的结果就是中文显示不出来,解决办法是在模板文件中将config中的元素一一取出;模板文件正确写法{% for i in config %}i{ endfor }有问题的写法{{config}}  //直接渲染列表整体将造成里面的中文无法正常显示二:模板概要Jinja模板是简单的一个纯文本文件,一般用html页面来书写。复制代码

{% for item in navigation %}

{{ item.caption }}

{% endfor %}

{{ a_variable }}{{ user.name }}{{ user['name'] }}{# a comment #}18.转自作者:IT蔷薇链接://www.jianshu.com/p/31a75d3d9270复制代码模版讲解:{{ ... }}:装载一个变量,模板渲染的时候,会使用传进来的同名参数这个变量代表的值替换掉。{% ... %}:装载一个控制语句。{# ... #}:装载一个注释,模板渲染的时候会忽视这中间的值。三:变量1)在模板中添加变量,可以使用(set)语句。{% set name='xx' %}之后就可以在页面文件中使用name这个变量了。在解释性语言中,变量的类型时运行时确定的,因此,这里的变量可以赋任何类型的值。上面的语句创建的是全局变量,从定义之后的文件部分中都可以访问 。2)局部变量可以使用with语句来创建一个内部的作用域,将set语句放在其中,这样创建的变量只在with代码块中才有效。{% with foo = 42 %}{{ foo }}{% endwith %}这样,foo变量就只能在with标签间可以使用。四:控制语句控制语句都是放在{% ... %}中,并且有一个语句{% endxxx %}来进行结束。1:if语句复制代码{% if kenny.sick %}Kenny is sick.{% elif kenny.dead %}You killed Kenny! You bastard!!!{% else %}Kenny looks okay --- so far{% endif %}转自:IT蔷薇链接://www.jianshu.com/p/31a75d3d9270复制代码2:for循环1)普通用法

{% for user in users %}

{{ user.username|e }}

{% endfor %}

2)遍历字典{% for key, value in my_dict.iteritems() %}

{{ key|e }}

{{ value|e }}

{% endfor %}3)在循环中加入else复制代码

{% for user in users %}

{{ user.username|e }}

{% else %}

no users found

{% endfor %}

复制代码4)Jinja2中for循环内置常量loop.index  当前迭代的索引(从1开始)loop.index0     当前迭代的索引(从0开始)loop.first  是否是第一次迭代,返回True\/Falseloop.last   是否是最后一次迭代,返回True\/Falseloop.length     序列的长度注意:不可以使用continue和break表达式来控制循环的执行。五:运算符+号运算符:可以完成数字相加,字符串相加,列表相加。但是并不推荐使用+运算符来操作字符串,字符串相加应该使用~运算符。-号运算符:只能针对两个数字相减。/号运算符:对两个数进行相除。%号运算符:取余运算。*号运算符:乘号运算符,并且可以对字符进行相乘。**号运算符:次幂运算符,比如2**3=8。in操作符:跟python中的in一样使用,比如{{1 in [1,2,3]}}返回true。~号运算符:拼接多个字符串,比如{{"Hello" ~ "World"}}将返回HelloWorld。六:Jiaja2模版最重要的部分——宏宏相当于一个搭建好的页面一部分,可以被引入,可以往宏传递参数。可以将一些经常用到的代码片段放到宏中,然后把一些不固定的值抽取出来当成一个变量,在使用宏时传递参数,从而将宏渲染成为页面的一部分。比如:定义一个input标签宏{% macro input(name, value='', type='text') %}

{% endmacro %}在其它地方使用这个宏快速创建出符合要求的input标签:

{{ input('username') }}

{{ input('password', type='password') }}

1)页面文件中导入宏——import在开发中,会将一些常用的宏单独放在一个文件中,在需要使用的时候,再从这个文件中进行导入。import语句的用法跟python中的import类似,可以直接import...as...,也可以from...import...或者from...import...as...。复制代码{% import 'forms.html' as forms %}  //导入宏文件

Username

{{ forms.input('username') }}

  //使用宏

Password

{{ forms.input('password', type='password') }}

{{ forms.textarea('comment') }}

复制代码导入模板并不会把当前上下文中的变量添加到被导入的模板中,我们可以在导入的时候使用with context 把上下文传进去:{% from '_helpers.html' import my_macro with context %}2)宏文件中引用其它宏——includeinclude语句可以把一个模板引入到另外一个模板中,类似于把一个模板的代码copy到另外一个模板的指定位置。{% include 'header.html' %}Body{% include 'footer.html' %}七:模版文件的继承模板可以继承,通过继承可以把模板中许多重复出现的元素抽取出来,放在父模板中,并且父模板通过定义block给子模板开一个口,子模板根据需要,再实现这个block进行具体内容定义。比如:父模版base.html如下:复制代码{% block head %} //开放一个地方,以待具体赋值{% endblock %}

{% block content %}{% endblock %}

{% block footer %}© Copyright 2008 by you;.{% endblock %}

转自:IT蔷薇链接://www.jianshu.com/p/31a75d3d9270复制代码然后定义子模版,对父模板中的block部分进行覆盖书写:复制代码{% extends "base.html" %}//1:继承父模板{% block title %}Index{% endblock %}//2:书写title block{% block head %}//3:书写head block{{ super() }}//调用父模板中的内容,如果不调用,则此处会被子模板中书写的内容覆盖掉{% endblock %}{% block content %}//4:书写content block

Index

Welcome to my awesome homepage.

{% endblock %}转自:IT蔷薇链接://www.jianshu.com/p/31a75d3d9270复制代码另外:模板文件中对block内容的调用,可以使用 self.blockName 的方式。

{{ self.title() }}

//调用title block的内容注意:在子模板中,所有的标签和代码都要添加到从父模板中继承的block中。否则,这些文本和标签将不会被渲染。(因为子模板相当于把内容嵌入到父模板到block中,而没有写到block中的内容当然不会被嵌入,也就不会被渲染。)八:过滤器过滤器是通过(|)符号进行使用的,例如:{{ name|length }}:将返回name的长度。过滤器相当于是一个函数,把当前的变量传入到过滤器中,然后过滤器根据自己的功能,再返回相应的值,之后再将结果渲染到页面中。Jinja2拥有许多过滤器:(转自://www.jianshu.com/p/31a75d3d9270)abs(value):返回一个数值的绝对值。示例:-1|absdefault(value,default_value,boolean=false):如果当前变量没有值,则会使用参数中的值来代替。示例:name|default('xiaotuo')——如果name不存在,则会使用xiaotuo来替代。boolean=False默认是在只有这个变量为undefined的时候才会使用default中的值,如果想使用python的形式判断是否为false,则可以传递boolean=true。也可以使用or来替换。escape(value)或e:转义字符,会将<、>等符号转义成HTML中的符号。示例:content|escape或content|e。first(value):返回一个序列的第一个元素。示例:names|firstformat(value,*arags,**kwargs):格式化字符串。比如:{{ "%s" - "%s"|format('Hello?',"Foo!") }}将输出:Helloo? - Foo!last(value):返回一个序列的最后一个元素。示例:names|last。length(value):返回一个序列或者字典的长度。示例:names|length。join(value,d=u''):将一个序列用d这个参数的值拼接成字符串。safe(value):如果开启了全局转义,那么safe过滤器会将变量关掉转义。示例:content_html|safe。int(value):将值转换为int类型。float(value):将值转换为float类型。lower(value):将字符串转换为小写。upper(value):将字符串转换为小写。replace(value,old,new): 替换将old替换为new的字符串。truncate(value,length=255,killwords=False):截取length长度的字符串。striptags(value):删除字符串中所有的HTML标签,如果出现多个空格,将替换成一个空格。trim:截取字符串前面和后面的空白字符。string(value):将变量转换成字符串。wordcount(s):计算一个长字符串中单词的个数。九:测试器测试器主要用来判断一个值是否满足某种类型,语法是:if...is...:{% if variable is escaped%}value of variable: {{ escaped }}{% else %}variable is not escaped{% endif %}Jinja2中测试器有:callable(object):是否可调用。defined(object):是否已经被定义了。escaped(object):是否已经被转义了。upper(object):是否全是大写。lower(object):是否全是小写。string(object):是否是一个字符串。sequence(object):是否是一个序列。number(object):是否是一个数字。odd(object):是否是奇数。even(object):是否是偶数。十:转义在模板渲染字符串的时候,字符串有可能包括一些非常危险的字符比如<、>等,这些字符会破坏掉原来HTML标签的结构,更严重的可能会发生XSS跨域脚本攻击,因此如果碰到<、>这些字符的时候,应该转义成HTML能正确表示这些字符的写法。对于一些不信任的字符串,可以通过{{ content_html|e }}或者是{{ content_html|escape }}的方式进行转义。如果想关闭自动转义,可以通过{{ content_html|safe }}的方式关闭自动转义。{%autoescape true/false%}...{%endautoescape%}可以将一段代码块放在中间,来关闭或开启自动转义:{% autoescape false %}

autoescaping is disabled here

{{ will_not_be_escaped }}{% endautoescape %}十一:模版页面中引入静态文件静态文件主要包括有CSS样式文件、JavaScript脚本文件、图片文件、字体文件等静态资源。在Jinja中加载静态文件只需要通过url_for全局函数就可以实现:引入static目录下的about.css文件。

本文由职坐标整理并发布,希望对同学们学习Python有所帮助,更多内容请关注职坐标编程语言Python频道!


本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 3 不喜欢 | 0
看完这篇文章有何感觉?已经有3人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程