标签:符号 format mat 注释 shu float enc 部分 多个参数
一:渲染模版
要渲染一个模板,通过render_template方法即可。
@app.route(‘/about/‘) def about(): # return render_template(‘about.html‘,user=‘username‘) return render_template(‘about.html‘,**{‘user‘:‘username‘})
渲染模版时有两种传递参数的方式:用 var=‘value‘ 传递一个参数;使用字典组织多个参数,并且加两个*号转换成关键字参数传入。
二:模板概要
Jinja模板是简单的一个纯文本文件,一般用html页面来书写。
1. <html lang="en"> 2. <head> 3. <title>My Webpage</title> 4. </head> 5. <body> 6. <ul id="navigation"> 7. {% for item in navigation %} 8. <li><a href="{{ item.href }}">{{ item.caption }}</a></li> 9. {% endfor %} 10. </ul> 11. 12. {{ a_variable }} 13. {{ user.name }} 14. {{ user[‘name‘] }} 15. 16. {# a comment #} 17. </body> 18.</html> 转自作者:IT蔷薇 链接:http://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蔷薇
链接:http://www.jianshu.com/p/31a75d3d9270
2:for循环
1)普通用法
<ul> {% for user in users %} <li>{{ user.username|e }}</li> {% endfor %} </ul>
2)遍历字典
{% for key, value in my_dict.iteritems() %} <dt>{{ key|e }}</dt> <dd>{{ value|e }}</dd> {% endfor %}
3)在循环中加入else
<ul> {% for user in users %} <li>{{ user.username|e }}</li> {% else %} <li><em>no users found</em></li> {% endfor %} </ul>
4)Jinja2中for循环内置常量
| loop.index | 当前迭代的索引(从1开始) |
| loop.index0 | 当前迭代的索引(从0开始) |
| loop.first | 是否是第一次迭代,返回True\/False |
| loop.last | 是否是最后一次迭代,返回True\/False |
| loop.length | 序列的长度 |
注意:不可以使用continue和break表达式来控制循环的执行。
五:过滤器
过滤器是通过(|)符号进行使用的,例如:{{ name|length }}:将返回name的长度。
过滤器相当于是一个函数,把当前的变量传入到过滤器中,然后过滤器根据自己的功能,再返回相应的值,之后再将结果渲染到页面中。
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):是否是偶数。{% macro input(name, value=‘‘, type=‘text‘) %} <input type="{{ type }}" name="{{ name }}" value="{{ value|e }}"> {% endmacro %}
在其它地方使用这个宏快速创建出符合要求的input标签:
<p>{{ input(‘username‘) }}</p> <p>{{ input(‘password‘, type=‘password‘) }}</p>
1)页面文件中导入宏——import
在开发中,会将一些常用的宏单独放在一个文件中,在需要使用的时候,再从这个文件中进行导入。
import语句的用法跟python中的import类似,可以直接import...as...,也可以from...import...或者from...import...as...。
{% import ‘forms.html‘ as forms %} //导入宏文件 <dl> <dt>Username</dt> <dd>{{ forms.input(‘username‘) }}</dd> //使用宏 <dt>Password</dt> <dd>{{ forms.input(‘password‘, type=‘password‘) }}</dd> </dl> <p>{{ forms.textarea(‘comment‘) }}</p>
导入模板并不会把当前上下文中的变量添加到被导入的模板中,我们可以在导入的时候使用with context 把上下文传进去:
{% from ‘_helpers.html‘ import my_macro with context %}
2)宏文件中引用其它宏——include
include语句可以把一个模板引入到另外一个模板中,类似于把一个模板的代码copy到另外一个模板的指定位置。
{% include ‘header.html‘ %}
Body
{% include ‘footer.html‘ %}
标签:符号 format mat 注释 shu float enc 部分 多个参数
原文地址:http://www.cnblogs.com/ygj0930/p/7170621.html