**1 小試身手**
* * * * *
1 建立模板文件
打開目錄D:\upnp5.6\htdocs\tp5\application\index,建立view目錄。
進入模塊的模板目錄D:\upnp5.6\htdocs\tp5\application\index\view\
建立模板文件test_fetch.html,輸入以下內容
~~~
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Thinkphp模板測試文件</title>
</head>
<body>
這里是Viewtest:test_fetch的模板文件
</body>
</html>
~~~
建立模板文件test_assign.html,輸入以下內容
~~~
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Thinkphp模板測試文件</title>
</head>
<body>
這里是Viewtest:test_assign的模板文件.<br>
名稱信息:{$name};<br>
郵件信息:{$email};<br>
</body>
</html>
~~~
* * * * *
2 建立渲染測試控制器文件
打開控制器目錄D:\upnp5.6\htdocs\tp5\application\index\controller\
建立模板測試文件Viewtest.php,輸入以下內容。
~~~
<?php
namespace app\index\controller;
use think\View;
class Viewtest
{
public function test_fetch(){
$view = new View();
return $view->fetch();
}
public function test_assign(){
$view = new View();
$view->assign('name','Thinkphp');
$view->assign('email','Test@ee.com');
return $view->fetch();
}
}
~~~
* * * * *
3 瀏覽器測試
輸入http://127.0.0.1/tp5/public/index.php/Index/Viewtest/test_fetch
輸出如下

輸入http://127.0.0.1/tp5/public/index.php/Index/Viewtest/test_assign
輸出如下

4 總結
框架的渲染由think/View類封裝。
可以單獨創建think/View對象,然后調用assign,fetch等方法。
也可以直接繼承think/Controller類,調用controller封裝的assign,fetch方法。
**2 開發場景**
這里是后端與前端的主要配合工作,根據公司流程安排分配合作。
**3 開發進階**
* * * * *
1 修改視圖渲染配置,
修改$view的view_suffix可以修改模板后綴,
修改$view的view_depr可以修改模板分層。
打開控制器目錄D:\upnp5.6\htdocs\tp5\application\index\controller\
新建Viewconfig.php文件,輸入以下內容
~~~
<?php
namespace app\index\controller;
use think\View;
class Viewconfig
{
public function test_fetch(){
$view = new \think\View(['view_suffix'=>'.htm','view_depr'=>'_']);
return $view->fetch();
}
public function test_assign(){
$view = new View();
$view->config(['view_suffix'=>'.htm','view_depr'=>'_']);
$view->assign('name','Thinkphp');
$view->assign('email','Test@ee.com');
return $view->fetch();
}
}
~~~
瀏覽器輸入
http://127.0.0.1/tp5/public/index.php/Index/Viewconfig/test_fetch
輸出如下

可知模板文件的路徑為application\index\view\viewconfig_test_fetch.htm
進入application\index\view\
分別建立對應模板文件,文件名格式為:**小寫控制器名稱_小寫方法名稱.后綴**,
viewconfig_test_fetch.htm,輸入以下內容
~~~
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Thinkphp模板測試文件</title>
</head>
<body>
這里是Viewconfig:test_fetch的模板文件
</body>
</html>
~~~
viewconfig_test_assign.htm,輸入以下內容
~~~
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Thinkphp模板測試文件</title>
</head>
<body>
這里是Viewconfig:test_assign的模板文件.<br>
名稱信息:{$name};<br>
郵件信息:{$email};<br>
</body>
</html>
~~~
瀏覽器輸入
http://127.0.0.1/tp5/public/index.php/Index/Viewconfig/test_fetch
http://127.0.0.1/tp5/public/index.php/Index/Viewconfig/test_assign
正常輸出模板。
view的相關配置參數見thinkphp\library\think\View.php文件。
~~~
protected $config = [
'theme_on' => false,
'auto_detect_theme' => false,
'var_theme' => 't',
'default_theme' => 'default',
'view_path' => '',
'view_suffix' => '.html',
'view_depr' => DS,
'view_layer' => VIEW_LAYER,
'parse_str' => [],
'engine_type' => 'think',
'namespace' => '\\think\\view\\driver\\',
];
~~~
* * * * *
2 自定義渲染引擎
tp5默認使用Think渲染引擎,
實現在\thinkphp\library\think\view\driver\Think.php文件。
~~~
namespace think\view\driver;
use think\Template;
class Think
{
private $template = null;
public function __construct($config = [])
{
$this->template = new Template($config);
}
public function fetch($template, $data = [], $cache = [])
{
if (is_file($template)) {
$this->template->display($template, $data, $cache);
} else {
$this->template->fetch($template, $data);
}
}
}
~~~
分析可知需要實現fetch()方法。
可以參考tp3.2的\ThinkPHP\Library\Think\Template\Driver\目錄下的
Smarty.class.php文件,添加Smarty渲染引擎的支持。
更多的模板引擎參考[官方手冊](http://www.hmoore.net/manual/thinkphp/1785)
* * * * *
3 自定義模板標簽
視圖渲染的模板標簽配置在thinkphp\library\think\Template.php文件中定義
~~~
protected $config = [
'view_path' => '',
'view_suffix' => '.html',
'cache_suffix' => '.php',
'tpl_deny_func_list' => 'echo,exit',
'tpl_deny_php' => false,
'tpl_begin' => '{',
'tpl_end' => '}',
'strip_space' => false,
'tpl_cache' => true,
'compile_type' => 'file',
'cache_prefix' => '',
'cache_time' => 0,
'cache_record_file' => 'cache_record_file',
'layout_on' => false,
'layout_name' => 'layout',
'layout_item' => '{__CONTENT__}',
'taglib_begin' => '{',
'taglib_end' => '}',
'taglib_load' => true,
'taglib_build_in' => 'cx',
'taglib_pre_load' => '',
'display_cache' => false,
'cache_id' => '',
'tpl_replace_string' => [],
'tpl_var_identify' => 'array',
'namespace' => '\\think\\template\\driver\\',
];
~~~
可以通過修改convention.php的模板配置參數
`'template_engine' => 'Think',`
或者$view->engine()方法修改模板標簽參數
**4 框架底層**
模板的視圖渲染是業務邏輯的內容輸出控制。
在控制器中,處理業務邏輯數據模型后,將輸出結果以模板文件的方式顯示。
視圖渲染將帶有think框架標簽的模板文件編譯為普通的php標簽模板文件,
然后由php運行環境解析執行后輸出到客戶端。
tp5繼承thinkphp3.2內置的豐富標簽庫與渲染引擎。
模板標簽的使用見[官方手冊 ](http://www.hmoore.net/manual/thinkphp/1793)。
- 更新記錄
- 概述
- 文件索引
- 函數索引
- 章節格式
- 框架流程
- 前:章節說明
- 主:(index.php)入口
- 主:(start.php)框架引導
- 主:(App.php)應用啟動
- 主:(App.php)應用調度
- C:(Controller.php)應用控制器
- M:(Model.php)數據模型
- V:(View.php)視圖對象
- 附:(App.php)應用啟動
- 附:(base.php)全局變量
- 附:(common.php)模式配置
- 附:(convention.php)全局配置
- 附:(Loader.php)自動加載器
- 附:(Build.php)自動生成
- 附:(Hook.php)監聽回調
- 附:(Route.php)全局路由
- 附:(Response.php)數據輸出
- 附:(Log.php)日志記錄
- 附:(Exception.php)異常處理
- 框架工具
- 另:(helper.php)輔助函數
- 另:(Cache.php)數據緩存
- 另:(Cookie.php)cookie操作
- 另:(Console.php)控制臺
- 另:(Debug.php)開發調試
- 另:(Error.php)錯誤處理
- 另:(Url.php)Url操作文件
- 另:(Loader.php)加載器實例化
- 另:(Input.php)數據輸入
- 另:(Lang.php)語言包管理
- 另:(ORM.php)ORM基類
- 另:(Process.php)進程管理
- 另:(Session.php)session操作
- 另:(Template.php)模板解析
- 框架驅動
- D:(\config)配置解析
- D:(\controller)控制器擴展
- D:(\model)模型擴展
- D:(\db)數據庫驅動
- D:(\view)模板解析
- D:(\template)模板標簽庫
- D:(\session)session驅動
- D:(\cache)緩存驅動
- D:(\console)控制臺
- D:(\process)進程擴展
- T:(\traits)Trait目錄
- D:(\exception)異常實現
- D:(\log)日志驅動
- 使用范例
- 服務器與框架的安裝
- 控制器操作
- 數據模型操作
- 視圖渲染控制
- MVC開發初探
- 模塊開發
- 入口文件定義全局變量
- 運行模式開發
- 框架配置
- 自動生成應用
- 事件與插件注冊
- 路由規則注冊
- 輸出控制
- 多種應用組織
- 綜合應用
- tp框架整合后臺auto架構快速開發
- 基礎原理
- php默認全局變量
- php的魔術方法
- php命名空間
- php的自動加載
- php的composer
- php的反射
- php的trait機制
- php設計模式
- php的系統時區
- php的異常錯誤
- php的輸出控制
- php的正則表達式
- php的閉包函數
- php的會話控制
- php的接口
- php的PDO
- php的字符串操作
- php的curl
- 框架心得
- 心:整體結構
- 心:配置詳解
- 心:加載器詳解
- 心:輸入輸出詳解
- 心:url路由詳解
- 心:模板詳解
- 心:模型詳解
- 心:日志詳解
- 心:緩存詳解
- 心:控制臺詳解
- 框架更新
- 4.20(驗證類,助手函數)
- 4.27(新模型Model功能)
- 5.4(新數據庫驅動)
- 7.28(自動加載)