以下是smarty语法
转自
assign
属性 | 类型 | 是否必须 | 描述 |
var | string | yes | 被赋值的变量名 |
value | string | yes | 赋给变量的值 |
<{assign var="age" value=20}><{$age}>输出: 20<{assign var="arr" value=array("s","b")}><{dump var=$arr}>输出:array 0 => string 's' (length=1) 1 => string 'b' (length=1)
foreach foreachelse
属性 | 类型 | 是否必须 | 描述 |
---|---|---|---|
from | string | yes | 待循环数组的名称 |
item | string | yes | 当前处理元素的变量名称 |
key | string | on | 当前处理元素的键名 |
name | string | on | 该循环的名称,用于访问该循环 |
概述: 用于在模板被执行时循环foreach 必须和 /foreach 成对使用, 且必须指定 from 和 item 属性.name 属性可以任意指定 .foreach 可以嵌套,但必须保证嵌套中的 foreach 名称唯一. from 属性(通常是数组)决定循环的次数。foreachelse 语句在 from 变量没有值的时候被执行. % 输出数组$array中所有元素 <{ foreach from=$array item=value key=key}> <{ $key}> : <{ $value}> <{/foreach}> 输出: a : c# b : php c : java % 当输出为空时, 输出foreachelse的值 <{ foreach from=$array item=value key=key}> <{ $key}> : <{ $value}> <{ foreachelse} empty <{/foreach}> 输出: empty
include
概述: 加载app级模板, 加载网店级模板可以用require
<{include file='site/product/goods_js.html' app=b2c}>
if,elseif,else
概述: 条件判断
修饰符 | 备用词 | 语法用例 | 说明 | php等同表达式 |
---|---|---|---|---|
== | eq,is | $a eq $b | equals | == |
!= | ne,neq | $a neq $b | not equals | != |
> | gt | $a gt $b | greater than | > |
< | lt | $a lt $b | less than | < |
>= | gte,ge | $a ge $b | greater than or equal | >= |
<= | lte,le | $a le $b | less than or equal | <= |
=== | $a === 0 | check for identity | === | |
! | not | not $a | negation(unary) | ! |
% | mod | $a mod $b | modulous | % |
is [not] odd | $a is not odd | [not] an odd number(unary) | $a%2!=0 | |
is [not] even | $a is not even | [not] an even number(unary) | $a%2=0 |
注意:每一个{if}必须与一个{/if}成对出现,允许使用{else}和{elseif},所有php条件和函数在这里同样适用,诸如||、or、&&、and、is_array()等等
下面是一串有效的限定符,它们的左右必须用空格分隔开,注意列出的清单中方括号是可选的,在适用情况下使用相应的等号(全等或不全等)。
<{if $name eq "yi"}>...<{elseif $name eq "yu"}>...<{else}>...<{/if}>{if $name == 'Fred' || $name == 'Wilma'}...{/if}% 允许使用圆括号{if ( $amount < 0 or $amount > 1000 ) and $volume >= #minVolAmt#}...{/if}% 可以嵌入函数 {if count($var) gt 0}...{/if}% 数组检查 {if is_array($foo) }.....{/if}% 是否空值检查 {if isset($foo) }.....{/if}% 测试值为偶数还是奇数{if $var is even}...{/if}{if $var is odd}...{/if}{if $var is not odd}...{/if}% 测试var能否被4整除
math
所属类: base_view_compiler
概述: 在模板中进行运算属性 | 类型 | 是否必须 | 描述 |
---|---|---|---|
equation | string | yes | 计算表达式 |
assign | string | no | 被赋值的变量名 |
format | string | no | 输出格式 |
<{math equation="x*2+y" format="--%03d--" assign="newkey" x=10 y=3}><{$newkey}>输出: --023-- --023--<{math equation="x*2+y" assign="newkey" x=10 y=3}>输出: 23
require
所属类: site_view_compiler
概述: 加载当前模板目录下模板文件属性 | 类型 | 是否必须 | 描述 |
---|---|---|---|
file | string | yes | 指定模板文件路径 |
<{require file="block/header.html"}>输出: 加载当前模板目录下block/header.html文件
include
引用view下html输出
<{include file="admin/sales/coupon/xxx.html" app=b2c}> <{include file="admin/sales/coupon/xxx.html" app=ome}>
main
所属类: site_view_compiler概述: 模板系统级区域属性 | 类型 | 是否必须 | 描述 |
view | string | no | 指定主区域模板路径 |
<{main}>输出: 使用系统内置的主区域模板进行渲染, 并输出主区域内容<{main view="abc.html"}>输出: 使用{$ecstore_root}/themes/{$template_name}/abc.html 作为主区域模板进行渲染, 并输出主区域内容
widgets
所属类: site_view_compiler
概述: 模板挂件区域属性 | 类型 | 是否必须 | 描述 |
---|---|---|---|
id | string | no | 挂件区域唯一标识, 一旦设定请勿轻易改动 |
<{widgets id='index-banner'}>输出: 为模板页面增加了一个挂件区域, 可通过后台模板可是化编辑中挂载挂件
default
所属类: base_view_compiler功能: 设置默认值<{assign var="key" value=''}><{$key|default:30}>输出: 30
ship_area
所属类: site_view_compiler
概述: 将内部地址转换为, 显示地址方式: modifier<{assign var="ship_area" value="mainland:广东/广州市/东山区:425"}><{$ship_area|ship_area}>输出: 广东广州市东山区
cur/cur_odr
所属类: ectools_view_compiler
概述: 将货币价格(默认系统里价格为基准货币价格)转换成当前货币价格, 并以当前货币格式输出别名: cur_odr% 当前货币和基准货币价格一致, 并且基准价格为人民币 <{ 40|cur}> 输出: ¥40.00
counter
所属类: base_view_helper
概述: 用于显示一个计数器counter 用于输出一个记数过程. counter 保存了每次记数时的当前记数值. 用户可以通过调节 interval 和 direction 调节该值. 也可以决定是否输出该值. 如果需要同时运行多个计数器,必须为它们指定不同的名称. 如果没有指定名称,模板引擎使用 “default” 作为缺省值.如果指定了 “assign” 这个特殊属性,该计数器的输出值将被赋给由 assign 指定的模板变量,而不是直接输出.
属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
name | string | No | default | 计数器的名称 |
start | number | No | 1 | 数器初始值 |
skip | number | No | 1 | 记数器间隔、步长 | |
direction | string | No | up | 记数器方向,(增/减) |
boolean | No | true | 是否输出值 | |
assign | string | No | n/a | 输出值将被赋给模板变量的名称 |
% counter 例子:0-<{ counter name="wocao" start=6 skip=3 direction=down print=false}> 1-<{ counter name="wocao"}> 2-<{ counter name="wocao"}> 3-<{ counter name="wocao" assign="result"}> 4-<{ counter name="wocao"}> 5-<{ $result}> ----- 0-<{ counter name="kkk" start=6 skip=2 direction=down print=false}> 1-<{ counter name="kkk"}> 2-<{ counter name="kkk"}> 3-<{ counter name="kkk" assign="result"}> 4-<{ counter name="kkk"}> 5-<{ $result}> <{ counter start=6 skip=3 direction=down print=false}> <{ counter}> <{ counter}> <{ counter assign="www"}> <{ $counter}> 输出: 0- 1-3 2-0 3- 4--6 5--3 ----- 0- 1-4 2-2 3- 4--2 5-0
html_options
所属类: base_view_helper
概述: 生成HTML的<select><option>标签建议: 详细用法可参考smarty文档属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
values | array | Yes, 除非使用 options 属性 | n/a | 下拉框值的数组 |
output | array | Yes, 除非使用 options 属性 | n/a | 下拉框显示的数组 |
selected | string/array | No | empty | 选中的项 |
options | 数组 | Yes, 除非使用 values 和 output | n/a | 键值对的数组,用于下拉框 |
name | string | No | empty | select组的名称 |
%必要的属性是values 和 output, 除非你使用组合的options来代替。 %除非提供了可选属性name, 才会创建 标签, 不然,只会生成
html_table
所属类: base_view_helper
概述: 可使用数组形式的数据来创建一个HTML的<table>, 此plugin是smarty的html_table简化版建议: 详细用法可参考smarty文档属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
loop | array | Yes | n/a | 循环赋值的数组 |
cols | mixed | No | 3 | 表 格的列数,或者是逗号分隔的列头文字列表,或是列头文字的数组。 如果cols属性为空,但设置了rows,将以rows数量和显示元素的总数进行计算得出列数, 以便每列能显示全部的元素。 如果rows和cols都设置了,那么cols会忽略默认值3. 如果设置cols为一个列表或数组,那么列数将取决于列表或数组的元素个数。 |
table_attr | string | No | border=”1″ | <table>标签的属性 |
tr_attr | string | No | empty | <tr>标签的属性 (循环) |
td_attr | string | No | empty | <td>标签的属性 (循环) |
trailpad | string | No | | 在最后行空单元格中填充的字符(如果有的话) |
<{assign var="loop" value=array(1,2,3,4,5,6,7,8,9,10)}><{html_table loop=$loop cols=3 }>输出:
1 | 2 | 3 |
4 | 5 | 6 |
7 | 8 | 9 |
json
所属类: base_view_helper概述: 对变量进行JSON编码属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
from | string | No | null | 需要进行JSON编码的变量 |
% $array 要进行JSON编码的变量 <{ assign var="array" value=array(1,2,3,4,array(2,4,5))}> <{ json from=$array}> 输出: [1,2,3,4,[2,4,5]]
mailto
所属类: base_view_helper
概述: 可以自动创建一个mailto:链接,而且可以选择编码方式。 对邮件编码可以使邮件地址更难以被网络爬虫抓取属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
address | string | Yes | n/a | 电邮地址 |
text | string | No | n/a | 显示的文字,默认是电邮地址 |
encode | string | No | none | 如何编码电邮。可以是none,hex,javascript或者javascript_charcode. |
cc | string | No | n/a | 抄送的电邮地址,用逗号隔开 |
bcc | string | No | n/a | 暗送的地址,用逗号隔开。 |
subject | string | No | n/a | 邮件标题 |
newsgroups | string | No | n/a | 发送到的新闻组地址,用逗号隔开。 |
followupto | string | No | n/a | 回执地址,用逗号隔开。 |
extra | string | No | n/a | 任何附加的链接信息,如样式表等 |
<{mailto address="me@domain.com"}><{mailto address="me@domain.com" text="send me some mail" subject="Hello to you!" cc="you@domain.com,they@domain.com" extra='class="email"'}> <{mailto address="me@domain.com" encode="javascript"}> <{mailto address="me@domain.com" encode="hex"}> 输出: me@domain.com send me some mail me@domain.com
appconf
所属类: base_view_helper
概述: 变相的使用app::get($app_id)->getConf($key)取数据属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
app | string | Yes | empty | app_id |
key | string | Yes | empty | key |
<{appconf app="site" key="site.name"}>输出: 商店名称
pager
所属类: base_view_helper
概述: 简单分页组件属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
data | array | Yes | paper数据 |
data格式:
属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
current | int | Yes | 需要进行JSON编码的变量 | |
total | int | Yes | 需要进行JSON编码的变量 | |
link | string | Yes | 需要进行JSON编码的变量 | |
token | string | Yes | 需要进行JSON编码的变量 |
分配变量$this->pagedata['pagers'] = array( 'current' => 33, 'total' => 3333, 'token' => '_PPP_' 'link'=>'index.php/shopadmin/#app=ecbook&ctl=admin_dbeav&act=index&p=_PPP_', ); html中调用 <{ assign var=data value=array('current=>33,'total <{ pagers data=$pagers}>
pagers
所属类: b2c_view_helper
概述: 分页组件属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
data | array | Yes | paper数据 |
data格式
属性 | 类型 | 是否必须 | 默认值 | 描述 |
---|---|---|---|---|
data | array | Yes | 需要进行JSON编码的变量 |
pager current 当前页 total 总页数 link 连接地址 <{ assign var="data" value=array('current'=>35,'total'=>3333,'token'=>'@@@','link'=>'http://a/@@@')}> <{ pagers data=$data}> <{ pager current=1 total=30 link='index.php/shopadmin/#app=ecbook&ctl=admin_dbeav&act=index' }>
效果预览:
pagers得第二种写法
分配变量$this->pagedata['pagers'] = array( 'current'=>2, 'total'=>20, 'link'=>'index.php/shopadmin/#app=ecbook&ctl=admin_dbeav&act=index', ); html中调用 <{ pagers data=$pagers}>
toinput隐藏框
参数: from 包含隐藏框的name和value的关联数组
先分配数据: $this->pagedata['toinput'] = array('a'=>'c#','b'=>'php','c'=>'java'); $this->page('list.html'); list.html: <{ toinput from=$toinput}> 输出:
amount
参数 第一个参数:货币币种(货币代码) 默认为人民币 第二个参数:是否为基本数据格式 false|true 第三个参数:是否需要改变费率 false|true 注意 此方法是继承ectools的,所以要调用必须安装ectools。 <{ 123466789|amount:'CNY'}> 输出效果:¥123,466,789.00
storager
根据image_id对图片显示进行修饰
参数 l 大图 m 中图 s 小图 默认显示原图 <{ $image_id|storager:'s'}> //显示小图,如无图片,显示默认设置图 <{ $ajuncts.thumbnail_pic|default:$env.conf.site.default_thumbnail_pic|storager:'s'}>
cdate控制日期输出
参数: FDATE Y-m-d SDATE y-m-d DATE m-d FDATE_FTIME Y-m-d H:i:s FDATE_STIME Y-m-d H:i SDATE_FTIME y-m-d H:i:s SDATE_STIME y-m-d H:i DATE_FTIME m-d H:i:s DATE_STIME m-d H:i 默认:FDATE_FTIME 先分配数据: $this->pagedata['time'] = time(); $this->page('list.html'); list.html: <{ $time|cdate:FDATE}> 输出: 2011-01-06
cut控制字符串输出
参数:第一个参数 输出几个字符 默认是80 第二个参数 后三个代替字符 默认是 ... 先分配数据: $this->pagedata['string'] = 'abcdefghijklmno'; $this->page('list.html'); list.html: <{ $string|cut:10}> <{ $string|cut:10:'+++'}> 输出: abcdefg... abcdefg+++
date
参数:参照php中date函数写参数 先分配数据: $this->pagedata['time'] = time(); $this->page('list.html'); list.html: <{ $time|date:'r'}> 输出: Thu, 06 Jan 2011 17:53:26 +0800
date_format
参数: 参数php中strftime函数写参数 先分配数据: $this->pagedata['time'] = time(); $this->page('list.html'); list.html: <{ $time|date_format:'%Y年'}> 输出: 2011年
t 将所要修饰的字符串调用语言包格式输出
参数: appid alt=$___b2c="删除"|t:'b2c'
number
对$number数据进行格式化
参数 0 把$number强制转换为int型原样输出 1 判断$number是否小于1,如果小于1则输出‘低于1’,否则如果是整数则原样输出,小数则进1位输出 2 判断$number是否小于1,如果小1则输出'超过99',否则输出100-$number 3 判断$number是否小于1,如果小于1则输出'低于1',否则输出对小数四舍五入的值 <{ 1234.247|number:3}> //1234.3
regex_replace正则替换
参数:第一参数:替换正则表达式. 第二参数:用来替换的文本字符串先分配数据: $this->pagedata['articleTitle'] = "Infertility unlikely to\nbe passed on, experts say."; $this->page('list.html'); list.html: <{ $articleTitle}> <{ $articleTitle|regex_replace:"/[\r\t\n]/":" "}> 输出: Infertility unlikely to be passed on, experts say. Infertility unlikely to be passed on, experts say.
region
参数:第一参数 被替换的字符串 第二参数 用来替换的字符串 先分配数据: $this->pagedata['region'] = "afsd/fsd:bbcd/czxc:fsd"; $this->page('list.html'); list.html: <{ $region}> <{ $region|replace:'/':'-'}> 输出: afsd/fsd:bbcd/czxc:fsd afsd-fsd:bbcd-czxc:fsd
strip替换空格
先分配数据: $this->pagedata['strip'] = "ss fbsd fsd fs "; $this->page('list.html'); list.html: <{ $strip}> <{ $strip|strip:''}> 输出: ss fbsd fsd fs ssfbsdfsdfs