你现在的位置:首页 > PHP网站建设知识库 > Yii > 正文

Yii:如何在CGridView列表控件使用了Ajax方式更新数据的情况下返回前一个页面

Yii框架提供的CGridView用来展示表格数据,具有较好的过滤/排序/分页功能。

但是在做yii程序开发时,可能会遇到下面这样的问题:

如果存在多页文章数据,在CGridView界面上浏览到后面的文章页,然后查看某个文章的信息,

这个时候再回退的时候,总是返回到列表的第一页,而不是刚才的历史页面。


解决方法有两个:

1个是禁用ajax效果,设置CGridView ajaxUpdate属性为false; 这个不是我想要的,因为牺牲了性能。

第2个方法是升级到Yii的高版本,>=1.1.12, 提供了一个enableHistory功能,

把列表视图(List.php)中把该CGridView的enableHistory属性设置为true, 再进行页面操作时,你会发现浏览器中的URL是带了ajax参数的完整请求。

然后在查看视图(View.php)中使用如下的语句达到返回历史页面的效果:

<div class="Action">  
    <?php echo XHtml::link(Yii::t('Trade','Back'), Yii::app()->request->urlReferrer); ?>  
</div>  

再进一步,如果要在这个查看页面进行审核操作,希望审核操作后也退回列表历史页面,
那么单单使用urlReferrer就不行了,因为它对于审核动作的处理逻辑而言记录了查看页面的url。

可以在查看页面中放一个隐藏字段:

    <input type="hidden" value=<?php echo Yii::app()->request->urlReferrer;?> id="backurl" name="backurl">

也就是把列表历史页面的路径做为请求参数传递给actionApprove, 那么在控制器的审核动作的处理完后就可以重定向到backurl.

public function actionApprove() {  
p;           //do your data update logic here  
        //then redirect to history list page  
p;           if(isset($_POST['backurl'])) $this->redirect($_POST['backurl']);  
}