ThinkPHP--模版基础

 

一.变量输出
在模版中输出变量是很是容易的,使用assign()方法,以键值对的方式传递变量和值。
//给模版传递一个变量
$user='新';
$this->assign('user',$user);
在模版中能够这么调用:
{$user}
模版编译后的结果是:
<?phpecho($user);?> //能够在Runtime能够查看
模版标签{和$之间不能用任何空格,不然没法解析。若是你想更换两个{}能够设置:
//修改默认标签
'TMPL_L_DELIM'=>'<{',
'TMPL_R_DELIM'=>'}>',
调用方式就必须改变:
<{$user}>
若是传递一个数组,咱们直接传递过去后,经过两种方式调用:
//给模版传递一个数组
$data['user']='新';
$data['email']='bbs@163.com';
$this->assign('data',$data);
调用方式为:
User:{$data.user}Email:{$data.email}
User:{$data['user']}Email:{$data['email']}
若是传递一个对象,咱们直接传递过去后,经过两种方式调用:
//给模版传递一个对象
$data=new\stdClass();
$data->user='新';
$data->email='bbs@163.com';
$this->assign('data',$data);
调用方式为:
User:{$data->user}Email:{$data->email}
User:{$data:user}Email:{$data:email}
二.系统变量
在模版中,不但能够输出PHP的系统变量,还能够输出ThinkPHP的系统变量。
//输出PHP系统变量
{$Think.server.script_name} //$_SERVER['SCRIPT_NAME']
{$Think.session.admin} //$_SESSION['admin']
{$Think.get.user} //$_GET['user']
{$Think.post.user} //$_POST['user']
{$Think.request.user} //$_REQUEST['user']
{$Think.cookie.name} //$_COOKIE['name']
//ThinkPHP的系统变量
{$Think.const.APP_PATH} //目录
{$Think.config.url_model} //URL模式
{$Think.lang.var_error} //语言变量
三.使用函数
若是有时,咱们须要在模版中使用PHP函数的话,能够按照下面的格式使用:
{$user|md5}
若是有多个参数要传递,能够参考以下设置:
{$date|date="Y-m-dH:i:s",###}
PS:表示date函数传入两个参数,每一个参数用逗号分割,这里第一个参数是Y-m-d
H:i:s,第二个参数是前面要输出的date变量,由于该变量是第二个参数,所以须要用###
标识变量位置,编译后的结果是:
<?phpecho(date($date,"Y-m-dH:i:s"));?>
前面输出变量,在后面定义,则不须要###
{$user|mb_substr=0,3,'UTF-8'}
多个函数用"|"隔开便可
{$user|mb_substr=0,3,'UTF-8'|md5|sha1}
PS:若是你以为以上写法须要在脑海里二次翻译,太过于麻烦,那么能够用如下的格
式写法:
{:md5(mb_substr($user,0,3,'UTF-8'))}
PS:我我的认为把这些数据处理,都尽量不要模版端,除非是必须在模版端才能处
理的。由于模版就是为了HTML和JS,而后就是提供数据,不要包含各类过滤和业务逻辑。
当传递过来的变量若是没有值的时候,模版提供了默认值输出功能。
{$user|default='什么都没有!'}
四.使用运算符
咱们能够在模版中使用运算符,包括对“+”、“-”、“*”、“/”、“%”、“--”和“++”的
支持。
{$data['num']+10} //中括号
{$data['num']+getNum()} //函数
PS:在使用运算符的时候,再也不支持语法和常规的函数用法:
{$data.num+10} //错误的
{$data['num']+getNum} //错误
模版还支持三元运算符:
{$user?'有值':'无值'}
五.包含文件
在一个系统中,能够包含通用的头文件和脚文件:header和footer。因为每一个页面
的头脚都是相同的,因此须要独立分离出来,再用包含文件引入他们。
咱们能够在View目录下default主题目录下建立一个public目录,这个目录专门存
放公共调用模版文件。
<includefile='Public/header'/>
<includefile='Public/footer'/>
也能够调用绝对路径模式:
<includefile='./Weibo/Home/View/default/Public/header.tpl'/>
同时调用多个模版文件:
<includefile='Public/header,Public/footer'/>
六.模版注释
模版支持注释功能,提供个模版制做人员参考。
{//这是注释}
{/*这也是注释*/}
{/*这是
多行注释*/}
七.模版继承
模版继承是一项灵活的模版布局方式,它相似于子类继承父类,而后子类还能够进行适
当的修改以知足当前页面的须要。
//基础模版须要子模版修改的部分能够用<block>包含,而且设置name值
<blockname="main">主要内容</block>
//子模版只要按一样的方法,修改<block>内部的值便可完成修改
<blockname="main">修改了</block>
//建立Public下base.tpl模版基页
<html>
<head>
<metahttp-equiv="Content-Type"content="text/html;charset=utf-8">
<blockname="title"><title>{$user}</title></block>
</head>
<body>
<includefile="Public/header"/>
<blockname="main">主要内容</block>
<includefile="Public/footer"/>
</body>
</html>
//使用<extend>导入模版基页,name为路径,和include导入方法一致
<extendname="Public/base"/>
<blockname="main">修改了</block>
八.模版布局
ThinkPHP的模版引擎内置了布局模版功能支持,能够方便实现模版布局以及布局嵌套
功能。有三种布局方式:
1.全局配置方式
//开启模版布局功能,并指定基础页
'LAYOUT_ON'=>true,
'LAYOUT_NAME'=>'Public/layout', //layout.tpl文件
//基础页,{__CONTENT__}将被子页面的内容替换
<includefile="Public/header"/>
{__CONTENT__}
<includefile="Public/footer"/>
//替换变量能够变动为{__REPLACE__}
'TMPL_LAYOUT_ITEM'=>'{__REPLACE__}',
//子模版不须要载入模版基页,能够在开头加上{__NOLAYOUT__}
{__NOLAYOUT__}
2.模版标签方式
标签方式,并不须要在系统作任何配置,和模版继承相似,直接引入便可。
//子模版引入模版基页
<layoutname="Public/layout"/>
//替换变量的方法
<layoutname="Public/layout"replace="{__REPLACE__}"/>
3.layout控制布局
这个方法是在控制器里操做的。
//开启布局,并引入默认地址基页
publicfunctionindex(){
layout(true);
}
//引入指定基页
publicfunctionindex(){
layout('Public/layout');
//layout(false); //关闭
}
九.模版替换
在模版渲染以前,系统还会对读取的模版内容进行一些特殊字符串替换操做,也就实现
了模版输出的替换和过滤。
__ROOT__:会替换成当前网站的地址(不含域名)
__APP__:会替换成当前应用的URL地址(不含域名)
__MODULE__:会替换成当前模块的URL地址(不含域名)
__CONTROLLER__(或者__URL__兼容考虑):会替换成当前控制器的URL地址(不
含域名)
__ACTION__:会替换成当前操做的URL地址(不含域名)
__SELF__:会替换成当前的页面URL
__PUBLIC__:会被替换成当前网站的公共目录一般是/Public/
'TMPL_PARSE_STRING' =>array(
'__PUBLIC__'=>'/Common',//更改默认的/Public替换规则
'__UPLOAD__'=>'/Uploads',//增长新的上传路径替换规则
)
PS:__PUBLIC__能够改为--PUBLIC--一样的也能够。php

相关文章
相关标签/搜索