ThinkPHP3.1的Widget新用法
thinkphp3.0版本的widget对action和view的支持力度是相对不够的,仅能够实现基本的模板渲染输出。而3.1版本的发布带来的多层mvc功能,给我们实现widget的方式带来了新的思路,且看是如何实现吧。
由于thinkphp3.1增加了对多层mvc的支持,因此3.1版本可以支持多层的控制器功能,由此我们就可以在控制器层再增加一层:widget层。
首先,还是在项目的lib目录下面创建一个widget目录,并且创建一个testwidget类(lib/widget/testwidget.class.php)如下:
class testwidget extends action{ public function hello($name=''){ echo ("hello,".$name."!"); } }
我们看到testwidget和之前的区别是没有继承widget类,而是直接继承了action类,这就代表着在testwidget中可以直接调用action的方法,包括对模板的渲染输出。
定义完成后,我们怎么调用这个widget呢?用w方法肯定行不通了,这次需要r方法出场了。
r方法的作用是远程调用模块的操作,但是3.1赋予了它新的作用,可以支持调用所有控制器层的操作方法,所以,我们可以在模板中这样来调用widget:
{:r('test/hello',array('thinkphp'),'widget')}
就可以实现在页面中的某个区域输出:
hello,thinkphp!
由于除了action控制器之外的其他控制器层是无法直接通过url访问的,所以这个widget方法只能通过r方法在内部调用才可以。
你可以在testwidget类中调用model来输出其他数据,如果需要渲染自身的模板,则可以直接调用display方法就行了。
class testwidget extends action{ public function hello($name=''){ $this->assign('name',$name); $this->display('test:hello'); } }
我们在项目的tpl/test/ 目录下面创建一个hello(tpl/test/hello.html)模板文件,添加输出:
hello,{$name}!
如果你希望和之前的widget一样,把模板文件放到当前目录下面,则可以使用:
class testwidget extends action{ public function hello($name=''){ $this->assign('name',$name); $this->display(dirname(__file__).'/test/hello.html'); } }
这个时候,你就可以把刚才定义的hello模板文件放入widget/test/ 目录下面了。