標記通用特性
① 短標記
{dede:tagname.name/}
等同于
{dede:tagname name='' /}
② 塊標記
{dede:tagname}
循環代碼
{/dede:tagname}
標記的具體語法及對應的PHP代碼
① 配置變量
{dede:config name='' value=''/}
配置變量可以在載入模板后通過 $tpl->GetConfig($name) 獲得,僅作為配置,不在模板中顯示。
② 短標記
{dede:global.name/} 外部變量 等同于 <?php echo $name; ?>
{dede:var.name/} var數組 等同于 <?php echo $_vars['name']; ?>
{dede:field.name/} field數組 等同于 <?php echo $fields['name']; ?>
{dede:cfg.name/} 系統配置變量 等同于 <?php echo $cfg_name; ?>
考慮到大多數情況下都會在函數或類中調用模板,因此 $_vars、$fields 數組必須聲明為 global 數組,否則模板引擎無法獲得它的值從而導致產生錯誤。
③ 自由調用塊標記
{tag:blockname bind='GetArcList' bindtype='class'}
循環代碼
{/tag:blockname}
必要屬性:
bind 數據源來源函數
bindtype 函數類型,默認是 class 可選為 sub
rstype 返回結果類型,默認是 array ,可選項為 string
自定義函數格式必須為 function(array $atts,object $refObj, array $fields);
在沒有指定 bind 綁定的函數的情況下,默認指向 MakePublicTag($atts,$tpl->refObj,$fields) 統一管理。
④ 固定塊標記
1.datalist
從綁定類成員函數GetArcList中獲取數組并輸出
{dede:datalist}
循環代碼
{/dede:datalist}
遍歷一個二給維數組,數據源是固定的,只適用用類調用。
等同于
{tag:blockname bind='GetArcList' bindtype='class' rstype='arrayu'}
循環代碼
{/tag:blockname}
2.label
從綁定函數中獲取字符串值并輸出
等同于 {tag:blockname bind='func' bindtype='sub' rstype='string'/}
3.pagelist
從綁定類成員函數GetPageList中獲取字符串值并輸出
等同于 {tag:blockname bind='GetPageList' bindtype='class' rstype='string'/}
4.include
{dede:include file=''/}
{dede:include filename=''/}
5.php
{dede:php
php 代碼
/}
或
{dede:php}
php代碼
{/dede:php}
6.If
僅支持 if ,else ,else 直接用{else}表示,但不支持{else if}這樣的語法 ,一般建議模板中不要使用太復雜的條件語法,如果確實有需要,可以直接使用 php 語法。
{dede:if 條件} a-block {else} b-block {/dede:if}
條件中允許使用 var.name 、global.name 、field.name、cfg.name 表示相應的變量。
如:
{dede:if field.id>10 }
{/dede:if}
7.遍歷一個 array 數組
{dede:array.name}
{dede:key/} = {dede:value/}
{/dede:array}
各種語法的具體編譯后的代碼,可查看dedetemplate.class.php的function CompilerOneTag(&$cTag)。
新聞熱點
疑難解答