Widget扩展
博客专区 > VHUOI 的博客 > 博客详情
Widget扩展
VHUOI 发表于1年前
Widget扩展
  • 发表于 1年前
  • 阅读 21
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 技术升级10大核心产品年终让利>>>   

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

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

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

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

 
  1. {:W('Cate/Menu')}

执行后的输出结果是: menuWidget

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

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

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

 
  1. {~W('Cate/Menu')}

传入参数

如果需要在调用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. }
  7. }

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

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

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

则会输出

 
  1. 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. }
  9. }

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

 
  1. <foreach name="menu" item="title">
  2. {$key}:{$title}
  3. </foreach>
标签: Widget
共有 人打赏支持
粉丝 11
博文 29
码字总数 22679
×
VHUOI
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: