每一个模块的模块文件是独立的,为了对模块文件更加有效的管理,ThinkPHP对模块文件进行目录划分,默认的模板文件定义规则是:php
视图目录/[模块主题/]'控制器名/操做名/操做名+模板后缀
html
默认的视图目录是模块的View目录(模块能够有多个视图文件目录),框架的默认视图文件后缀是.html
。thinkphp
在每一个模块主题下面,是以模块下面的控制器名为目录,而后是每一个控制器的具体操做模板文件,如:
User控制器的add操做 对应的模块文件就应该是:
./Application/Home/View/User/add.html
若是默认视图层不是View,设置如:
'DEFAULT_V_LAYER'=>'Template',//设置默认的视图层名称
,对应的模板文件就变成了:./Application/Home/Template/User/add.html
。
模板文件的默认后缀是.html
,能够经过TMPL_TEMPLATE_SUFFIX来配置。
'TMPL_TEMPLATE_SUFFIX'=>'.tpl'
定义后,User控制器的add操做 对应的模板文件就变成是:./Application/Home/View/User/add.tpl
数据库
模板主题能够对相同的控制器输出进行不一样的布局和样式调整
一个模块须要支持多套模板文件的话,就可使用模板主题功能。默认状况下,没有开启模板主题功能,若是须要开启,设置DEFAULT_THEME参数便可:mvc
// 设置默认的模板主题 'DEFAULT_THEME'=>'default'
采用模板主题后,须要在视图目录下面建立对应的主题目录,和不启用模板主题的状况相比,模板文件只是多了一层目录:框架
View/User/add.html //没有启用模板主题以前 View/default/User/add.html //启用模板主题以后
在视图渲染输出以前,咱们能够经过动态设置来改变须要使用的模板主题。函数
//在控制器中动态改变模板主题 $this->theme('blue')->display('add');
若是要在模板中输出变量,必须在控制器中把变量传递给模板,经过assign方法对模板变量赋值布局
$this->assign('name',$value); //下面的写法是等效的 $this->name=$value;
assign方法必须在display
和show方法
以前调用,而且系统只会输出设定的变量,其余变量不会输出(系统变量例外)。fetch
系统变量能够经过特殊的标签输出,无需赋值模板变量this
赋值后,就能够在模板文件中输出变量,若是使用的是内置模板的话,就能够这样输出:{$name}
输出多个模板变量,可使用下面的方式:
$array['name'] = 'thinkphp'; $array['email'] = 'fdsf@123.com'; $array['phone'] = '123456789'; $this->assign($array);
模板定义后就能够渲染模板输出,系统也支持直接渲染内容输出,模板赋值必须在模板渲染以前操做。
渲染模板输出最经常使用的是使用display方法,调用格式:
display('[模板文件]'[,'字符编码'][,'输出类型'])
模板文件的写法支持下面几种:
| 用法 |描述 |
|:-------|:--------------|
|不带任何参数 |自动定位当前操做的模板文件 |
|[模块@][控制器:][操做] |经常使用写法,支持跨模块 模板主题能够和theme方法配合 |
|完整的模板文件名 |直接使用完整的模板文件名(包括模板后缀)|
eg.
//不带任何参数 自动定位当前操做的模板文件 $this->display();
一般默认的视图目录是View
若是没有按照模板定义的规则来定义模板文件(或者须要调用其余控制器下面的某个模板),使用:
//表示调用当前控制器下面的edit模块 $this->display('edit'); //表示调用Member控制器下面的read模块 $this->display('Member:read');
若是咱们使用了模板主题功能,那么也能够支持主题调用,使用:
\\表示调用blue主题下面的User控制器的edit模块 $this->theme('blue')->display('User:edit');
T函数用于生成模板文件名,用法:
T([资源://][模块@][主题/][控制器/]操做,[视图分层])
T函数的返回值为一个完整的模板文件名,能够直接用于display和fetch方法进行渲染输出。
eg.
T('Public/menu'); //返回 当前模块/View/Public/menu.html T('blue/Public/menu'); //返回 当前模块/View/blue/Public/menu.html T('Public/menu','Tpl'); //返回 当前模块/Tpl/Public/menu.html T('Admin@Public/menu'); //返回 Admin/View/Public/menu.html
在display方法中直接使用T函数
//使用T函数输出模板 $this->display(T('Admin@Public/menu'));
T函数能够输出不一样的视图分层模块。
若是须要获取渲染模板的输出内容而不是直接输出,可使用fetch方法。
eg.
$content = $this->fetch('Member:edit');
使用fetch方法获取渲染内容后,能够进行过滤和替换等操做。
若是没有定义任何模板文件,或者把模板内容存储到数据库的话,就须要使用show方法来渲染输出。
show方法调用格式:
show('渲染内容'[,'字符编码'][,'输出类型'])
eg.$this->show($content);