视图实例化
视图功能由\think\View
类配合视图驱动(模板引擎)类一起完成,目前的内置模板引擎包含PHP原生模板和Think模板引擎。
因为新版的控制器可以无需继承任何的基础类,因此在控制器中如何使用视图取决于你怎么定义控制器。
继承\think\Controller
类
如果你的控制器继承了\think\Controller
类的话,则无需自己实例化视图类,可以直接调用控制器基础类封装的相关视图类的方法。
// 渲染模板输出
return $this->fetch('hello',['name'=>'thinkphp']);
下面的方法可以直接被调用: | 方法 | 说明 |
---|---|---|
fetch | 渲染模板输出 | |
display | 渲染内容输出 | |
assign | 模板变量赋值 | |
engine | 初始化模板引擎 |
如果需要调用View类的其它方法,可以直接使用$this->view
对象:
助手函数
如果你只是需要渲染模板输出的话,可以使用系统提供的助手函数view
,可以完成相同的功能:
return view('hello',['name'=>'thinkphp']);
助手函数调用格式:
view('[模板文件]'[,'模板变量(数组)'][,模板替换(数组)])
无论你是否继承think\Controller
类,助手函数都可以使用,也是最方便的一种。
直接实例化视图类(不建议)
任何情况下,你都可以直接实例化视图类进行渲染模板。
// 实例化视图类
$view = new View();
// 渲染模板输出 并赋值模板变量
return $view->fetch('hello',['name'=>'thinkphp']);
实例化视图类的时候,可以传入模板引擎相关配置参数,例如:
// 实例化视图类
$view = new View([
'type' => 'think',
'view_path' => '',
'view_suffix' => 'HTML',
'view_depr' => '/',
]);
// 渲染模板输出 并赋值模板变量
return $view->fetch('hello',['name'=>'thinkphp']);
如果需要使用应用自己扩展的模板引擎驱动,可以使用:
// 实例化视图类
$view = new View([
'type' => '\org\template\Think',
'view_path' => '',
'view_suffix' => 'html',
'view_depr' => '/',
]);
如果实例化不当,很容易导致配置参数无效的情况。因此如果不是必要,不建议直接实例化
View
类进行操作。