下拉列表更改时批量状态更新

时间:2013-04-25 10:57:07

标签: jquery yii cgridview

我有批量状态上传的下拉列表

echo CHtml::dropDownList('updateStatus',
                'updateStatus',
                Lookup::items('NodeStatus'),
                array(
                      'prompt' => '',
                      'ajax'=>array(
                                    'type'=>'POST',
                                    'url' => CController::createUrl('node/bulkStatus'),
                                    'data'=> array('updateStatus' => 'js:this.value', 'autoId' => 'js:$("input[name=autoId]:checked").map(function () {return this.value;}).get().join(",")'), 
                                    'success'=>'reloadGrid',
                                    'update'=>'#msg', //selector to update
                                    ),
                                )                          
                );
?>

我很难在上面的ajax选项中获取输入复选框的所有选中值的值,如下所示:

<input id="autoId_6" type="checkbox" name="autoId[]" value="11">
<input id="autoId_5" type="checkbox" name="autoId[]" value="10">
<input id="autoId_8" type="checkbox" name="autoId[]" value="6">

我已经查看了firebug中的帖子,autoId为空且updateStatus工作正常。我想将autoId值作为数组发送到我可以遍历数组的操作:

public function actionBulkStatus()
{ 
    if(isset($_POST['updateStatus']))
    {
        $autoIdAll = $_POST['autoId'];
        if(count($autoIdAll)>0)
        {
            foreach($autoIdAll as $autoId)
            {
                $model=$this->loadModel($autoId);
                $model->Status = $_POST['updateStatus'];
                $model->save();
            }
        }
        echo "successfully update";
    }
}

如何在dropDownList的ajax数据选项中将autoId检查值作为数组传递?

1 个答案:

答案 0 :(得分:0)

保持简单。 从.join(",")移除.get().join(..),复选框名称应为autoId,删除[],您应该可以。