企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
在模板中输出变量的方法很简单,例如,在控制器中我们给模板变量赋值: ~~~ $name = 'ThinkPHP'; $this->assign('name',$name); $this->display(); ~~~ 然后就可以在模板中使用: ~~~ Hello,{$name}! ~~~ 模板编译后的结果就是: ~~~ Hello,<?php echo($name);?>! ~~~ 这样,运行的时候就会在模板中显示: `Hello,ThinkPHP!` 注意模板标签的`{`和`$`之间不能有任何的空格,否则标签无效。所以,下面的标签 ~~~ Hello,{ $name}! ~~~ 将不会正常输出name变量,而是直接保持不变输出: `Hello,{ $name}!` 普通标签默认开始标记是`{`,结束标记是 `}`。也可以通过设置`TMPL_L_DELIM`和`TMPL_R_DELIM`进行更改。例如,我们在项目配置文件中定义: ~~~ 'TMPL_L_DELIM'=>'<{', 'TMPL_R_DELIM'=>'}>', ~~~ 那么,上面的变量输出标签就应该改成: ~~~ Hello,<{$name}>! ~~~ 后面的内容我们都以默认的标签定义来说明。 模板标签的变量输出根据变量类型有所区别,刚才我们输出的是字符串变量,如果是数组变量, ~~~ $data['name'] = 'ThinkPHP'; $data['email'] = 'thinkphp@qq.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} ~~~