A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

CJuiTabs 显示分页UI组件,和Yii Framework 开发教程(17) UI 组件 TabView示例功能类似,它封装了 JUI tabs插件。
前基本用法如下:
widget('zii.widgets.jui.CJuiTabs', array(     
'tabs'=>array(
    'Static tab'=>'Static content',
    'Render tab'=>$this->renderPartial('pages/_content1',null,true),
    'Ajax tab'=>array('ajax'=>array('ajaxContent','view'=>'_content2')),
    ),
'options'=>array(
    'collapsible'=>true,
    'selected'=>1,
    ),
'htmlOptions'=>array(     
    'style'=>'width:500px;'
    ),     
)); ?>
显示了三个页面不同内容显示方法,Static Tab显示一个静态内容,Render Tab使用Partial渲染一个页面 ,而Ajax Tab则通过AJAX显示一个页面,注意后面两个需要在SiteController中定义Actions 如下:
public function
actions()     
{
    return array(
        'page'=>array(
                'class'=>'CViewAction',
                ),
        // ajaxContent action renders
        //"static" pages stored under 'protected/views/site/pages'
        // They can be accessed via:
        //index.php?r=site/ajaxContent&view=FileName
        'ajaxContent'=>array(
                'class'=>'application.controllers.AjaxViewAction',
            ),
        );     
}其中AjaxViewAction为一自定义ViewAction,为CViewAction的子类,可以显示静态页面,其定义如下:
class AjaxViewAction extends CViewAction
{     
    private $_viewPath;
    public function run()
    {
        if(Yii::app()->request->isAjaxRequest)
        {
            $this->resolveView($this->getRequestedView());
            $controller=$this->getController();
            $controller->renderPartial($this->view, null, false, true);
        }
        else
            throw new CHttpException(400,'Invalid request.
               Please do not repeat this request again.');
    }
}

1 个回复

倒序浏览
奈斯
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马