如何在没有 refreshing/changing 页面的情况下刷新 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。在我定向到的这个页面上,视图创建得很好。我需要在当前页面上 rebuild/refresh 的小部件,而不是将我发送到其他地方。任何有关解决方案的想法都将不胜感激。

我会这样做:

  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. 在 Controller 操作中做任何您想做的事并使用 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');
          }
       }
    }