变量输出

来源:互联网 发布:java游戏破解版下载 编辑:程序博客网 时间:2024/06/05 01:01
我们已经知道了在Action中使用assign方法可以给模板变量赋值,赋值后怎么在模板文件中输出变量的值呢?
如果我们在Action中赋值了一个name模板变量:
  1. $name = 'ThinkPHP';
  2. $this->assign('name',$name);
使用内置的模板引擎输出变量,只需要在模版文件使用:
  1. {$name}
模板编译后的结果就是
  1. <?php echo($name);?>
最后运行的时候就可以在标签位置显示ThinkPHP的输出结果。
注意模板标签的{和$之间不能有任何的空格,否则标签无效。
1
普通标签默认开始标记是 {,结束标记是 }。也可以通过设置TMPL_L_DELIM和TMPL_R_DELIM进行更改。例如,我们在项目配置文件中定义:
  1. 'TMPL_L_DELIM'=>'<{',
  2. 'TMPL_R_DELIM'=>'}>',
那么,上面的变量输出标签就应该改成:
  1. <{$name}>
后面的内容我们都以默认的标签定义来说明。
4
assign方法里面的第一个参数才是模板文件中使用的变量名称。如果改成下面的代码:
  1. $name = 'ThinkPHP';
  2. $this->assign('name2',$name);
再使用{$name} 输出就无效了,必须使用 {$name2}才能输出模板变量的值了。

如果我们需要把一个用户数据对象赋值给模板变量:
  1. $User = M('name');
  2. $user = $User->find(1);
  3. $this->assign('user',$user);
也就是说$user其实是一个数组变量,我们可以使用下面的方式来输出相关的值:
  1. {$user['name']}// 输出用户的名称
  2. {$user['email']} // 输出用户的email地址
如果$user是一个对象而不是数组的话,
  1. $User = M('name');
  2. $User->find(1);
  3. $this->assign('user',$User);
可以使用下面的方式输出相关的属性值:
  1. {$user:name}// 输出用户的名称
  2. {$user:email} // 输出用户的email地址
3.1版本以后,类的属性输出方式有所调整,支持原生的PHP对象写法,所以上面的标签需要改成:
  1. {$user->name}// 输出用户的名称
  2. {$user->email} // 输出用户的email地址
为了方便模板定义,还可以支持点语法,例如,上面的
  1. {$user['name']}// 输出用户的名称
  2. {$user['email']} // 输出用户的email地址
可以改成
  1. {$user.name}
  2. {$user.email}
因为点语法默认的输出是数组方式,所以上面两种方式是在没有配置的情况下是等效的。我们可以通过配置TMPL_VAR_IDENTIFY参数来决定点语法的输出效果,以下面的输出为例:
  1. {$user.name}
如果TMPL_VAR_IDENTIFY设置为array,那么
{$user.name}和{$user['name']}等效,也就是输出数组变量。
如果TMPL_VAR_IDENTIFY设置为obj,那么
{$user.name}和{$user:name}等效,也就是输出对象的属性。
如果TMPL_VAR_IDENTIFY留空的话,系统会自动判断要输出的变量是数组还是对象,这种方式会一定程度上影响效率,而且只支持二维数组和两级对象属性。
如果是多维数组或者多层对象属性的输出,可以使用下面的定义方式:
  1. {$user.sub.name}// 使用点语法输出
或者使用
  1. {$user['sub']['name']}// 输出三维数组的值
  2. {$user:sub:name}// 输出对象的多级属性
0 0
原创粉丝点击