symfony中twig的模板过滤器

过滤器

变量可以被过滤器修饰。过滤器和变量用(|)分割开。过滤器也是可以有参数的。过滤器也可以被多重使用。

通用过滤器

date过滤器

1.1版本新增时区支持,1.5版本增加了默认的日期格式。
格式化时间,这个过滤器和php的date函数无限类似,可处理与 strtotime 兼容的字符串,或 DateTime/DateInterval 的实例,可选的第二个参数用于指定时区,如果所修饰的数据为空则默认为当前时间

{{ article.publishedTime|date(‘Y-m-d H:i:s’) }}

输出: 2014-7-12 12:11:11

format过滤器

和php的printf函数一样,用来替换占位符

<span class=”days”>
    {{ “%02d”|format(countdown.days) }}
</span>天

输出: 12天

replace过滤器

{{ “教师可在直播开始前%hour%小时内进入直播教室,以准备相关教学资料.”
    |replace({‘%hour%’: hour}) }}

输出: 教师可在直播开始前1小时内进入直播教室,以准备相关教学资料.

number_format过滤器

他是php函数 number_format的一个包装 直接见函数参考php函数 number_format吧

<span class=”rating-num”>
    {{ course.rating|number_format(1) }}分
</span>

输出: 5分

url_encode过滤器

编码链接字符串,等同于php函数urlencode

{{ data|url_encode() }}

json_encode过滤器

编码JSON格式,等同于php函数json_encode

{{ data|json_encode() }}

convert_encoding过滤器

编码转换,第一个参数指定转换后的编码,第二个参数指定转换前的编码,本函数依赖于iconv 或者mbstring 所以至少需要安装一个

{{ data|convert_encoding(‘UTF-8’, ‘iso-2022-jp’) }}

title过滤器

将字符串中每个单词的首字母大写,等同于 ucwords

{{ ‘my first car’|title }}

输出: My First Car

capitalize过滤器

将字符串的首字母大写,其余字母小写的格式,等同于 ucfirst

{{ ‘my first car’|capitalize }}

输出: My first car

nl2br过滤器

将字符串里的 \n 替换成 <br/>

{{ “I like Twig.\nYou will like it too.”|nl2br }}

输出: 
I like Twig. <br />
You will like it too.

join过滤器

将数组的各个元素按指定分隔符组成字符串

{{ [1, 2, 3]|join }}

输出: 123

{{ [1, 2, 3]|join(‘|’) }}

输出: 1|2|3

reverse 过滤器

反转一个数组,或者是一个实现了Iterator接口的对象,在 array_reverse 的基础上增加了对字符串的处理

{% for use in users|reverse %}  
    …  
{% endfor %}

length过滤器

返回一个数组或者字符串的长度,等同于 count 和 strlen 的结合体

{% if users|length > 10 %}  
    …  
{% endif %}

sort过滤器

对数组排序

{% for use in users|sort %}  
    …  
{% endfor %}

keys过滤器

将数组的全部键名提取成一个数组,等同于 array_keys

{% for key in array|keys %}  
    …
{% endfor %}

escape过滤器

将字符串安全地处理成合法的指定数据,支持多种转换模式,默认模式为 html,其他可选模式有 html_attr、js、css、url,主要转义 & < > ‘ ” 。并且它有个简写方式 e。

{{ user.username|escape }}  
{{ user.username|e }}

raw过滤器

用于在autoescape标签内部,标记出不需要转义的内容。

<div class=”thread-body”>
    {{article.body |raw }}
</div>

merge过滤器

用来合并数组,近似于 array_merge 。如 {{ 数组1|merge(数组2) }} 

{% set items = { ‘id’:course.id} %}

{% set items = items|merge({type:’all’}) %}

posted @ 2016-07-14 11:37  php91  阅读(562)  评论(0编辑  收藏  举报