## 变量输出
在模板中输出变量的方法很简单,例如,在控制器中我们给模板变量赋值:
~~~
$name = 'TookPHP';
$this->assign('name',$name);
$this->display();
~~~
然后就可以在模板中使用:
~~~
Hello,{$name}!
~~~
模板编译后的结果就是:
~~~
Hello,<?php echo($name);?>!
~~~
这样,运行的时候就会在模板中显示: `Hello,ThinkPHP!`
注意模板标签的{和$之间不能有任何的空格,否则标签无效。所以,下面的标签
~~~
Hello,{ $name}!
~~~
将不会正常输出name变量,而是直接保持不变输出: `Hello,{ $name}!`
普通标签默认开始标记是{,结束标记是 }。也可以通过设置`TPL_TAG_LEFT`和`TPL_TAG_RIGHT`进行更改。例如,我们在项目配置文件中定义:
~~~
'TPL_TAG_LEFT'=>'<{',
'TPL_TAG_RIGHT'=>'}>',
~~~
那么,上面的变量输出标签就应该改成: `Hello,<{$name}>!`
后面的内容我们都以默认的标签定义来说明。
模板标签的变量输出根据变量类型有所区别,刚才我们输出的是字符串变量,如果是数组变量,
~~~
$data['name'] = 'TookPHP';
$data['email'] = 'test@163.com';
$this->assign('data',$data);
~~~
那么,在模板中我们可以用下面的方式输出:
~~~
Name:{$data.name}
Email:{$data.email}
~~~
或者用下面的方式也是有效:
~~~
Name:{$data['name']}
Email:{$data['email']}
~~~
当我们要输出多维数组的时候,往往要采用后面一种方式。
如果data变量是一个对象(并且包含有name和email两个属性),那么可以用下面的方式输出:
~~~
Name:{$data:name}
Email:{$data:email}
~~~
或者
~~~
Name:{$data->name}
Email:{$data->email}
~~~