当前位置:首页 > CMS教程 > Thinkphp > 列表

Thinkphp 框架扩展之Widget扩展实现方法分析

发布:smiling 来源: PHP粉丝网  添加日期:2022-03-02 09:37:16 浏览: 评论:0 

这篇文章主要介绍了Thinkphp 框架扩展之Widget扩展实现方法,结合实例形式分析了Thinkphp 框架Widget扩展概念、原理、实现方法及操作注意事项,需要的朋友可以参考下。

本文实例讲述了Thinkphp 框架扩展之Widget扩展实现方法,分享给大家供大家参考,具体如下:

Widget扩展

Widget扩展一般用于页面组件的扩展。
举个例子,我们在页面中实现一个分类显示的Widget,首先我们要定义一个Widget控制器层 CateWidget,如下:

  1. namespace Home\Widget; 
  2. use Think\Controller; 
  3. class CateWidget extends Controller { 
  4.   public function menu(){ 
  5.     echo 'menuWidget'
  6.   } 

然后,我们在模版中通过W方法调用这个Widget。

{:W('Cate/Menu')}

执行后的输出结果是:

menuWidget

传入参数

如果需要在调用Widget的时候 使用参数,可以这样定义:

  1. namespace Home\Widget; 
  2. use Think\Controller; 
  3. class CateWidget extends Controller { 
  4.   public function menu($id,$name){ 
  5.     echo $id.':'.$name
  6.   } 

模版中的参数调用,使用:

{:W('Cate/Menu',array(5,'thinkphp'))}

传入的参数是一个数组,顺序对应了menu方法定义的参数顺序。

则会输出

5:thinkphp

模板支持

Widget可以支持使用独立的模板,例如:

  1. namespace Home\Widget; 
  2. use Think\Controller; 
  3. class CateWidget extends Controller { 
  4.   public function menu(){ 
  5.     $menu = M('Cate')->getField('id,title'); 
  6.     $this->assign('menu',$menu); 
  7.     $this->display('Cate:menu'); 
  8.   } 

CateWiget类渲染了一个模版文件 View/Cate/menu.html,在menu.html模版文件中的用法:

  1. <foreach name="menu" item="title"
  2. {$key}:{$title
  3. </foreach>

Tags: Thinkphp框架扩展 Widget

分享到: