Yii ClientSide Validation on Render Partial not Working

前端 未结 3 1314
無奈伤痛
無奈伤痛 2021-02-10 07:01

I have a Yii form which calls a render partial from another model (team has_many team_members). I want to call via ajax a partial view to add members in team/_form. All works (c

相关标签:
3条回答
  • 2021-02-10 07:24

    The actual problem is that the ActiveForm saves its attributes to be validated in the "settings" data attribute. I see you are already using indexes so what you need to add the new elements to this settings object in order for the validation to work. After the ajax response this is what must be done:

    //Get the settings object from the form
    var settings = $("#form").data('settings');
    //Get all the newly inserted elements via jquery
    $("[name^='YourModel']", data).each(function(k, v) {
        //base attribute skeleton
        var base = {
            model : 'YourModel',
            enableAjaxValidation : true,
            errorCssClass : 'error',
            status : 1,
            hideErrorMessage : false,
        };
    
        var newRow = $.extend({
            id : $(v).attr('id'),
            inputID : $(v).attr('id'),
            errorID : $(v).attr('id') + '_em_',
            name : $(v).attr('name'),
         }, base);
         //push it to the settings.attribute object
         settings.attributes.push(newRow);
     });
     //update the form
     $("#form").data('settings', settings);
    

    ```

    This way the ActiveForm will be aware of the new fields and will validate them.

    0 讨论(0)
  • 2021-02-10 07:37

    Well, setting processOutput to true in renderPartial (in order to make client validation works on newly added fields) will not help in this case since it will only work for CActiveForm form and you don't have any form in your _member view (only input fields).

    A simple way to deal with this kind of problem could be to use only ajax validation, and use CActiveForm::validateTabular() in your controller to validate your team members.

    0 讨论(0)
  • 2021-02-10 07:43

    If you will look at the CActiveForm::run:

    $cs->registerCoreScript('yiiactiveform');
    //...
    $cs->registerScript(__CLASS__.'#'.$id,"jQuery('#$id').yiiactiveform($options);");
    

    Then you will understand that you validation will not work, because you render partial and not the whole page. And these scripts show up at the bottom of the page. So you should solve this by execute these scripts.

    After you partial is rendered, try to get activeform script which should be stored at the scipts array:

    $this->renderPartial('_member',array('model'=> $model, 'index'=> $index));
    $script = Yii::app()->clientScript->scripts[CClientScript::POS_READY]['CActiveForm#team-form'];
    

    after, send it with rendered html to page:

    echo "<script type='text/javascript'>$script</script>"
    

    Also remember before you will append recieved html on the page you should include jquery.yiiactiveform.js, if you not already did it(by render another form, or registerCoreScript('yiiactiveform')), on the page from calling ajax request. Otherwise javascript error will raised.

    Hope this will help.

    Edit: Sorry I'm not understood that you are render part of form and not the whole. But you validation will not work exactly with the same issue. Because jQuery('#$id').yiiactiveform($options); script was not created for the field.

    0 讨论(0)
提交回复
热议问题