ThinkPHP开发指南-视图-模板输出:修订间差异
无编辑摘要 |
无编辑摘要 |
||
第2行: | 第2行: | ||
<div style="clear:both;"></div> | <div style="clear:both;"></div> | ||
[[模板]]变量赋值后就需要调用模板文件来输出相关的变量,模板调用通过display方法来实现。我们在操作方法的最后使用: | |||
'''PHP代码''' | |||
<pre> | |||
$this->display(); | |||
</pre> | |||
根据前面的模板定义规则,因为系统会按照默认规则自动定位模板文件,所以通常display方法无需带任何参数即可输出对应的模板。这是模板输出的最简单的用法。事情总有特例,或者根本不需要按模块进行分目录存放,不过display方法总是能够帮你解决问题。Display方法提供了几种规则让你可以随心所欲的输出需要的模板,无论你的模板文件在什么位置。 | |||
'''下面来看具体的用法:''' | |||
*调用当前模块的其他操作模板 | |||
'''格式''':display('操作名') | |||
'''例如''',假设当前操作是User模块下面的read操作,我们需要调用User模块的edit操作模版,使用: | |||
'''PHP代码''' | |||
<pre> | |||
$this->display('edit'); | |||
</pre> | |||
不需要写模板文件的路径和后缀。 | |||
*调用其他模块的操作模板 | |||
'''格式''':display('分组名:模块名:操作名') 其中分组名是可选的 | |||
'''例如''',当前是User模块,我们需要调用Member模块的read操作模版 ,使用: | |||
'''PHP代码''' | |||
<pre> | |||
$this->display('Member:read'); | |||
</pre> | |||
如果要调用分组Admin的Member模块的read操作模板,可以使用: | |||
'''PHP代码''' | |||
<pre> | |||
$this->display('Admin:Member:read'); | |||
</pre> | |||
这种方式也不需要写模板文件的路径和后缀,严格来说,这里面的模块名和操作名并不一定需要有对应的模块或者操作,只是一个目录名称和文件名称而已,例如,你的项目里面可能根本没有Public模块,更没有Public模块的menu操作,但是一样可以使用 | |||
'''PHP代码''' | |||
<pre> | |||
$this->display('Public:menu'); | |||
</pre> | |||
输出这个模板文件。理解了这个,模板输出就清晰了。 | |||
*调用其他主题的操作模板 | |||
'''格式''':display('主题名@模块名:操作名') | |||
'''例如''':我们需要 调用Xp主题的User模块的edit操作模版,使用: | |||
'''PHP代码''' | |||
<pre> | |||
$this->display('Xp@User:edit'); | |||
</pre> | |||
这种方式需要指定模块和操作名 | |||
*直接全路径输出模板 | |||
'''格式''':display('模板文件名') | |||
'''例如''',我们直接输出当前的Public目录下面的menu.html模板文件,使用: | |||
'''PHP代码''' | |||
<pre> | |||
$this->display('./Public/menu.html'); | |||
</pre> | |||
这种方式需要指定模板路径和后缀,这里的Public目录是位于当前项目入口文件位置下面。如果是其他的后缀文件,也支持直接输出,例如: | |||
'''PHP代码''' | |||
<pre> | |||
$this->display('./Public/menu.tpl'); | |||
</pre> | |||
只要./Public/menu.tpl是一个实际存在的模板文件。如果使用的是相对路径的话,要注意当前位置是相对于项目的入口文件,而不是模板目录。事实上,display方法还有其他的参数和用法。有时候某个模板页面我们需要输出指定的编码,而不是默认的编码,可以使用: | |||
'''[[PHP]]代码''' | |||
<pre> | |||
$this->display('Member:read', 'gbk'); | |||
</pre> | |||
或者输出的模板文件不是text/[[html]]格式的,而是[[XML]]格式的,可以用: | |||
'''PHP代码''' | |||
<pre> | |||
$this->display('Member:read', 'utf-8', 'text/xml'); | |||
</pre> | |||
[[category:ThinkPHP]] | [[category:ThinkPHP]] |
2010年5月14日 (五) 13:54的最新版本
导航:返回上一页
模板变量赋值后就需要调用模板文件来输出相关的变量,模板调用通过display方法来实现。我们在操作方法的最后使用:
PHP代码
$this->display();
根据前面的模板定义规则,因为系统会按照默认规则自动定位模板文件,所以通常display方法无需带任何参数即可输出对应的模板。这是模板输出的最简单的用法。事情总有特例,或者根本不需要按模块进行分目录存放,不过display方法总是能够帮你解决问题。Display方法提供了几种规则让你可以随心所欲的输出需要的模板,无论你的模板文件在什么位置。
下面来看具体的用法:
- 调用当前模块的其他操作模板
格式:display('操作名')
例如,假设当前操作是User模块下面的read操作,我们需要调用User模块的edit操作模版,使用:
PHP代码
$this->display('edit');
不需要写模板文件的路径和后缀。
- 调用其他模块的操作模板
格式:display('分组名:模块名:操作名') 其中分组名是可选的
例如,当前是User模块,我们需要调用Member模块的read操作模版 ,使用:
PHP代码
$this->display('Member:read');
如果要调用分组Admin的Member模块的read操作模板,可以使用:
PHP代码
$this->display('Admin:Member:read');
这种方式也不需要写模板文件的路径和后缀,严格来说,这里面的模块名和操作名并不一定需要有对应的模块或者操作,只是一个目录名称和文件名称而已,例如,你的项目里面可能根本没有Public模块,更没有Public模块的menu操作,但是一样可以使用
PHP代码
$this->display('Public:menu');
输出这个模板文件。理解了这个,模板输出就清晰了。
- 调用其他主题的操作模板
格式:display('主题名@模块名:操作名')
例如:我们需要 调用Xp主题的User模块的edit操作模版,使用:
PHP代码
$this->display('Xp@User:edit');
这种方式需要指定模块和操作名
- 直接全路径输出模板
格式:display('模板文件名')
例如,我们直接输出当前的Public目录下面的menu.html模板文件,使用:
PHP代码
$this->display('./Public/menu.html');
这种方式需要指定模板路径和后缀,这里的Public目录是位于当前项目入口文件位置下面。如果是其他的后缀文件,也支持直接输出,例如:
PHP代码
$this->display('./Public/menu.tpl');
只要./Public/menu.tpl是一个实际存在的模板文件。如果使用的是相对路径的话,要注意当前位置是相对于项目的入口文件,而不是模板目录。事实上,display方法还有其他的参数和用法。有时候某个模板页面我们需要输出指定的编码,而不是默认的编码,可以使用:
PHP代码
$this->display('Member:read', 'gbk');
或者输出的模板文件不是text/html格式的,而是XML格式的,可以用:
PHP代码
$this->display('Member:read', 'utf-8', 'text/xml');