现在的位置: 首页 > 综合 > 正文

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

2013年05月10日 ⁄ 综合 ⁄ 共 923字 ⁄ 字号 评论关闭

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

但是你可能会遇到下面这样的问题:

如果存在多页文章数据,在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() {
            //do your data update logic here
            //then redirect to history list page
            if(isset($_POST['backurl'])) $this->redirect($_POST['backurl']);
    }

iefreer

抱歉!评论已关闭.