使用情景…
遇到一个bug:在数据库中存的数据,取出到前端后自带换行,(导致js中的引号、分号直接被换到下一行),js无法正常读取数据。猜测可能是在数据录入的时候输入了什么特殊符号,但是把数据删掉重新录入读取出来之后还是自带换行(在python后台输出也是,前端也是),于是想出使用jinja模板中的
trim
,截掉前后的空白字符,问题暂时解决。
示例:
{% for node in result %}
var obj = new Object();
obj.id ={{ node.id }};
obj.pId ={{ node.pid }};
obj.text = '{{ node.name|trim }}'; // 取出的数据含有换行 使用trim过滤
obj.attributes = {};
obj.attributes['filename'] = '{{ node.filename }}';
obj.attributes['url'] = '{{ node.url }}';
zNodes.push(obj);
{% endfor %}
Jinja模板的过滤器
过滤器是通过|
符号进行使用的,例如:{{ name|length }}
:将返回name的长度。
Jinja2拥有许多过滤器:
abs(value)
:返回一个数值的绝对值。示例:-1|abs
default(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|first
format(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)
:计算一个长字符串中单词的个数。