如何在不刷新/更改页面的情况下刷新Yii小部件


How to refresh Yii widget without refreshing/changing page

我在提交TbActiveForm和renderPartial时遇到问题,它会擦除我的页面并只显示部分视图。我只想在我的操作触发并完成后重新加载小部件。我还使用模态来显示和进行更改。

视图:

$form = $this->beginWidget(
     'booster.widgets.TbActiveForm',
     array(
         'id' => 'horizontalForm',
         'type' => 'horizontal',
         'action' => Yii::app()->createUrl('orderControl/order/returns.save'),
          )
     );
     echo $form->hiddenField(
          $editReturnFormModel,
          'orderId',
          array(
              'value' => $editReturnFormModel->orderId
         )
     );
     $this->widget(
           'bootstrap.widgets.TbButton',
           array('buttonType' => 'submit', 'type' => 'primary', 'label' => 'Save')
                        );
     $this->endWidget();

行动:

$this->controller->renderPartial('ScModules.orderControl.widgets.ReturnsWidget.views._returnItems', array('returnsDataProvider'=>$returnsDataProvider, 'editReturnFormModel'=>$editReturnFormModel));

另一点是Yii::app()->createUrl('orderControl/order/returns.save')是一起更改页面url。在我指向的这个页面上,视图创建得很好。我需要小部件在当前页面上重建/刷新,而不是将我发送到其他地方。任何关于解决方案的想法都将不胜感激。

以下是我要做的:

  1. 将表单小部件封装在div或任何您喜欢的块标记中。<div id="myFormWrapper"> (your widget goes here) </div>
  2. 在表单中添加自定义ID(ID="formId")并提交按钮(ID="submitButtonId")
  3. 添加一些jQuery以提交表单,并用新的小部件替换旧的小部件

    $(document).on('click', '#submitButtonId' , function() {
        $.ajax({
            type: 'POST',
            url: $('#formId').attr('action'),
            data : $('#formId').serialize(),
            beforeSend : function(){
                    //do anything you want before sending the form
            },
            success : function(data){
                    //We'll replace the old form with the new form widget  
                    $('#myFormWrapper').html(data);
            },
            error : function(data){
                console.log('ops');
            },
        });
        return false;
    });
  1. 在控制器操作中执行任何要执行的操作,然后使用renderPartial

    //The action below should be the same that you used in the action attribute of the form
    public function actionProcessForm(){
       $model = new MyFormModelName();
       if(isset($_POST['MyFormModelName'])){
          $model->attributes = $_POST['MyFormModelName'];
          if($model->save()){
             //Do whatever you want here
             $returnsDataProvider = new CActiveDataProvider('YourModel');
             $this->renderPartial('//folder/to/your/view',  array('returnsDataProvider'=> $returnsDataProvider, 'editReturnFormModel'=>$editReturnFormModel));
          }else{
              //You might want to render something else here
              $this->renderPartial('errorViewPage');
          }
       }
    }