在thinkphp中,fetch方法用于渲染模板文件输出,该方法不会直接渲染输出,而是支持模板或者内容的标签解析,返回解析后的内容,渲染输出系统也会自动调用send方法进行渲染输出,语法为“$this->fetch(模板名称);”。
本文操作环境:Windows10系统、ThinkPHP6版、Dell G3电脑。
实例化视图类
5.0模板渲染提供了fetch 和display两个方法,最常用的是fetch
fetch方法用于渲染模板文件输出,而
立即学习“PHP免费学习笔记(深入)”;
display方法则是渲染内容输出。
// 实例化视图类 $view = new \think\View(); // 渲染模板输出 return $view->fetch();
如果你的控制器继承了\think\Controller类的话,则可以直接使用
// 渲染模板输出 return $this->fetch();
需要注意的是,ThinkPHP5的视图fetch方法不会直接渲染输出,只是返回解析后的内容。如果在控制器类返回 视图解析内容的话,渲染输出系统会自动调用think\Response类的send方法进行渲染输出。
模板定位规则
模板文件目录默认位于模块的view目录下面,视图类的fetch方法中的模板文件的定位规则如下:
如果调用没有任何参数的fetch方法:
return $view->fetch();
则按照系统的默认规则定位模板文件到:
>[info] ### [模板文件目录]/当前控制器名(小写)/当前操作名(小写).html
如果(指定操作)调用:
return $view->fetch('add');
则定位模板文件为:
>[info] ### [模板文件目录]/当前控制器名/add.html
如果调用控制器的某个模板文件使用:
return $view->fetch('user/add');
则定位模板文件为:
[模板文件目录]/user/add.html
全路径模板调用:
return $view->fetch(MODULE_PATH.'view/public/header.html');
则定位模板文件为:
MODULE_PATH.'view/public/header.html'
推荐学习:《PHP视频教程》