当我点击Yii2 GridView :: widget的复选框列的复选框时,幕后会发生什么?

时间:2017-06-12 14:37:38

标签: javascript checkbox yii2 yii2-advanced-app yii2-grid

当您单击gridview的Yii2复选框列下的复选框时,使用以下控制器功能捕获javascript生成的数组'keylist'。

我犯了错误:没有意识到每次点击复选框都会在幕后运行Doit操作。

通过单击最左侧的红色警报ajax按钮,查看Yii调试器工具栏中的日志。

单击POST 404的配置文件链接以获取您故意的错误日志。

public function actionDoit()
{
  //1.  Deliberately throw an exception to catch the following
  //    getKeys javascript which I created under scripts.js and 
  //    saved under D:\wamp\www\advanced\web\frontend\web\js
  /*
        function getKeys(){
            var keys = $('#w1').yiiGridView('getSelectedRows'); 
            $.post({  url: "/product/doit",
                 dataType: "json",
                     data: {keylist: keys},
            //Uncomment the following line to verify getKeys function is being run when clicking on checkboxcolumn 
               //success: alert(keys)
        });}

        This can be seen in small ajax redbox alert in the Yii debugger tool (installed by default) on the toolbar. Click on far right <  
        to have the debugger tool present.
        Look for ajax red alert box on far left of toolbar when checkbox is clicked. (not form button is clicked)
   */ 
   //2. Did not use .... var keys = $('#grid').yiiGridView('getSelectedRows'); 
   //   Instead I used .... var keys = $('#w1').yiiGridView('getSelectedRows'); 

   //3. The following code appears in my gridview.
   /*
    * <?= GridView::widget([
    'dataProvider' => $dataProvider,
    'filterModel' => $searchModel,
    'columns' => [
        ['class' => 'yii\grid\SerialColumn'],
        ['class' => 'yii\grid\CheckboxColumn',
        //the name of checkbox's under the checkboxcolumn. Not to be confused with 'keylist'.
        //They appear with [] appended to selection.
        'name'=>'selection',
        'multiple'=>true,
        'checkboxOptions'=>function ($model, $key, $index){
            return ['id'=>"{$model->id}", 'onclick'=>'js:getKeys()' ,'value' => $model->name];
        }
    */ 
    // 4. Look for a POST 404 red alert by clicking on the ajax alert box on far left of Yii debugger toolbar.
    // 5. If you see something like the following....
    //    13:27:54.723 error yii\web\HttpException:404 yii\web\NotFoundHttpException: Here 9 and request is is arrayAJAXPOST in D:\wamp29 
    // 6. ....your 'doit' controller action function has successfully been run EACH TIME YOU CLICKED on a  checkbox. 
    // 7. ....NOTE: No button was clicked. All the clicked checkbox values are sent to the controller when you click a checkbox.
    // 8. ....This can be verified by uncommenting //success: alert(keys);
    // 9. ....It made no difference changing $.post with $.ajax under the script.

   if (isset($_POST['keylist']))
   {
       //Equivalent to: $arr=$_POST['keylist'];
       $request = Yii::$app->request;
       $arr = $request->post('keylist');

       //Unnecessary: $keys = \yii\helpers\Json::decode($params,true);

       //Extract the array $arr into individual keys separated by a comma,
       $keys = implode(",",$arr);

       if (is_array($arr)) {$message = "is array ";}
       if ($request->isAjax) { $message .= "AJAX "; }
       if ($request->isPost) { $message .= "POST "; }
       throw new NotFoundHttpException('Here '.$keys.' and request is '.$message);
    }

}

0 个答案:

没有答案