Widget扩展_扩展_帮助文档_Thinkphp手册



Widget扩展一般用于页面组件的扩展。

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

namespace HomeWidget;
use ThinkController;
class CateWidget extends Controller {
    public function menu(){
        return 'menuWidget';
    }
}

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

{:W('Cate/Menu')}

执行后的输出结果是: menuWidget

如果,CateWidget类的menu方法改成:

namespace HomeWidget;
use ThinkController;
class CateWidget extends Controller {
    public function menu(){
        echo 'menuWidget';
    }
}

模版中的用法则需要改成:

{~W('Cate/Menu')}

传入参数

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

namespace HomeWidget;
use ThinkController;
class CateWidget extends Controller {
    public function menu($id,$name){
        echo $id.':'.$name;
    }
}

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

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

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

则会输出

5:thinkphp

模板支持

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

namespace HomeWidget;
use ThinkController;
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模版文件中的用法:


{$key}:{$title}

温馨提示: 本文最后更新于2024-12-31 21:13:57,某些文章具有时效性,若有错误或已失效,请在下方 留言或联系 蚂蚁官方
© 版权声明
THE END
喜欢就支持一下吧
点赞10赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容