gridview - 如何在 Yii CGridView 中处理选定的行?

标签 gridview checkbox yii

我有一个带有 CCheckBoxColumn 和 selectableRows = 2 的 CGridView。用户可以选择 GridView 的多行。

GridView 用于显示未批准评论的列表,我希望能够选择要批准的评论,点击“批准”按钮并为每个已批准的评论更新评论表中的字段。

我该怎么做?

我对 ajax 解决方案持开放态度,但我真正想知道的是如何使用普通帖子获取 Controller 操作代码中的评论 ID 列表。我更喜欢一个不涉及 JavaScript 的解决方案,除非这是唯一的选择。

最佳答案

我能够在不依赖 javascript 的情况下完成这项工作。步骤如下:

将表单添加到您的 View 文件

这将允许将作为 html 输入元素的复选框值发布到您的 Controller 。

<?php echo CHtml::beginForm(); ?>

<?php $this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider'=>$dataProvider,
    'selectableRows' => 2,
    'columns' => array(
        array(
            'id' => 'selectedIds',
            'class' => 'CCheckBoxColumn'
        ),
        'id',
        'username',
        'content',
        array(
            'name' => 'created',
            'value' => '$data->created'
        ),
    ), 
));
?>

<div>
<?php echo CHtml::submitButton('Approve', array('name' => 'ApproveButton')); ?>
<?php echo CHtml::submitButton('Delete', 
array('name' => 'DeleteButton',
'confirm' => 'Are you sure you want to permanently delete these comments?'));
?>
</div>

<?php echo CHtml::endForm(); ?>

请注意,通过向提交按钮传递“名称”选项,它可以知道在 Controller 中单击了哪个按钮。

为您的复选框列指定一个 ID

以前我有:

'columns' => array(
    array(
        'class' => 'CCheckBoxColumn'
    ),

我将其更改为:

'columns' => array(
    array(
        'id' => 'selectedIds',
        'class' => 'CCheckBoxColumn'
    ),

现在,您可以通过 $_POST['selectedIds'] 将所选行作为数组引用。默认情况下,CCheckBoxColumn 将使用 gridview 中模型项的主键(但您可以更改它),因此 selectedIds 将是所选主键的数组。

修改 Controller 以处理选定的行

public function actionApprove()
{
    if (isset($_POST['ApproveButton']))
    {
        if (isset($_POST['selectedIds']))
        {
            foreach ($_POST['selectedIds'] as $id)
            {
                $comment = $this->loadModel($id);
                $comment->is_published = 1;
                $comment->update(array('is_published'));
            }
        }
    }

    // similar code for delete button goes here

    $criteria = new CDbCriteria();
    $criteria->condition = 'is_published = 0';
    $criteria->order = 'created DESC';

    $dataProvider = new CActiveDataProvider('Comment');
    $dataProvider->criteria = $criteria;

    $this->render('approve', array(
        'dataProvider' => $dataProvider,
    ));
}

我使用这篇 Yii wiki 文章来帮助我想出这个解决方案:Working with CGridView in Admin Panel

不确定这是否是理想的方法,但它确实有效。我愿意接受改进建议或其他方法。

关于gridview - 如何在 Yii CGridView 中处理选定的行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12923415/

相关文章:

php - Yii2 GridView SqlDataprovider 排序不工作

c# - 无法在 ASP.NET 中转换类型为 System.Web.UI.WebControls.GridView 的对象

asp.net - 在客户端单击时重新加载 Gridview

javascript - Bootstrap 模式停止复选框选择

php - 内部服务器错误 500,运行 Yii 时出现内存不足错误

c# - 无法在 GridView 上设置单元格颜色

android - 缺少复选框

Java如何根据另一个复选框是否已被选中来启用和禁用复选框

php - 比较表 Yii

php - 保存与 Yii 有多对多关系的模型