这篇文章主要介绍了thinkPHP下的widget扩展用法,结合实例形式分析widget扩展的具体使用技巧与注意事项,需要的朋友可以参考下
本文实例讲述了thinkPHP下的widget扩展用法。分享给大家供大家参考,具体如下:
Widget扩展用于在页面根据需要输出不同的内容,Widget扩展的定义是在项目的Lib\Widget目录下面定义Widget类库,例如下面定义了一个用于显示最近的评论的Widget:
位于Lib\Widget\ShowCommentWidget.class.php
Widget类库需要继承Widget类,并且必须定义render方法实现,例如:
render方法必须使用return返回要输出的字符串信息,而不是直接输出。
Widget也可以调用Widget类的renderFile方法,渲染模板后进行输出。
在项目的lib目录下建立widget目录,与action目录同级。
建立TestWidget.class.php:
class TestWidget extends Widget{
public function render($data){
//print_r($data);
$data['id']=$data['id'];
$data['info']=$data['info'];
$content = $this->renderFile('index',$data);
//print_r($content);
return $content;
}
}
在此目录下建立对应的Test文件夹,下面放$this->rendFile调用的html页面。
index.html 通过使用循环显示数据的信息
<div>
这是widget调用的模板页面
<foreach name="id" item="vo"> <span style="color:#ff0000">//注意:id对应与$data的键值</span>
{$vo}
</foreach>
<br>
<foreach name="info" item="vo"> <span style="color:#ff0000">//info对应于$data的键值</span>
<foreach name="vo" item="v">
{$v}
</foreach>
</foreach>
</div>
action方法:
IndexAction.class.php
代码如下:
class TestAction extends Action{
public function index(){
$info=array(array("1","AA","title"),array("2","BB","title2"));
$this->assign("info",$info);
$this->display();
}
}
action调用的tpl中的html页面的为index.html
代码如下:
<div>
这个是test调用的action<br>
{:W('Test',array("id"=>array("ID","name","title"),"info"=>$info))} <span style="color:#cc0000">//传递给TestWidget.class.php 的参数,要以array格式传递</span>
</div>
运行IndexAction.class.php
页面显示如下:
这样就把show.html中的内容包含进来了
name什么时候用widgte呢?
widget通常是一些封装好了的JS效果组件,直接调用‘加入参数就可以得到一些效果,例如,TAB菜单、旋转木马、图片轮播等交互效果
比如网站的菜单栏。右边常不更新的栏目之类的…
方便多次调用,比如在页面上左侧显示一个新闻列表,每个页面如果都调用这个列表,是不是得在每个控制器里写一遍相同的代码,不累么,用widget可能只需要写一次,然后模板中多次使用
希望本文所述对大家基于thinkPHP框架的PHP程序设计有所帮助。 |