Thinkphp 框架扩展之Widget扩展实现方法分析
这篇文章主要介绍了Thinkphp 框架扩展之Widget扩展实现方法,结合实例形式分析了Thinkphp 框架Widget扩展概念、原理、实现方法及操作注意事项,需要的朋友可以参考下
本文实例讲述了Thinkphp 框架扩展之Widget扩展实现方法。分享给大家供大家参考,具体如下:
Widget扩展
Widget扩展一般用于页面组件的扩展。
举个例子,我们在页面中实现一个分类显示的Widget,首先我们要定义一个Widget控制器层 CateWidget,如下:
1 2 3 4 5 6 7 | namespace Home\Widget; use Think\Controller; class CateWidget extends Controller { public function menu(){ echo 'menuWidget' ; } } |
然后,我们在模版中通过W方法调用这个Widget。
1 | {:W( 'Cate/Menu' )} |
执行后的输出结果是:
menuWidget
传入参数
如果需要在调用Widget的时候 使用参数,可以这样定义:
1 2 3 4 5 6 7 | namespace Home\Widget; use Think\Controller; class CateWidget extends Controller { public function menu( $id , $name ){ echo $id . ':' . $name ; } } |
模版中的参数调用,使用:
1 | {:W( 'Cate/Menu' , array (5, 'thinkphp' ))} |
传入的参数是一个数组,顺序对应了menu方法定义的参数顺序。
则会输出
5:thinkphp
模板支持
Widget可以支持使用独立的模板,例如:
1 2 3 4 5 6 7 8 9 | namespace Home\Widget; use Think\Controller; class CateWidget extends Controller { public function menu(){ $menu = M( 'Cate' )->getField( 'id,title' ); $this ->assign( 'menu' , $menu ); $this ->display( 'Cate:menu' ); } } |
CateWiget类渲染了一个模版文件 View/Cate/menu.html。 在menu.html模版文件中的用法:
1 2 3 | < foreach name= "menu" item= "title" > { $key }:{ $title } </ foreach > |