web-dev-qa-db-fra.com

jQuery Valider avec l'erreur Editeur Summernote: impossible de remplacer la propriété

J'utilise MVC5 pour créer un formulaire avec l'éditeur Summernote.

Code de rasoir:

<div class="form-group">
      @Html.LabelFor(model => model.Content, htmlAttributes: new { @class = "control-label" })
      @Html.EditorFor(model => model.Content, new { htmlAttributes = new { @class = "form-control post-content"} })
      @Html.ValidationMessageFor(model => model.Content, "", new { @class = "text-danger" })
</div>

JS:

$('#blog-form .post-content').summernote({
  height: 400,                
  minHeight: 300,            
  codemirror: {
    theme: 'default'
  }
});

Avec la configuration ci-dessus, le contrôle de l'éditeur rend bien. Cependant, dès que je quitte l'éditeur, c'est-à-dire onBlur, le message d'erreur suivant s'affiche dans la console:

Uncaught TypeError: Cannot read property 'replace' of undefined
    at $.validator.escapeCssMeta (jquery.validate.js:1014)
    at $.validator.errorsFor (jquery.validate.js:995)
    at $.validator.prepareElement (jquery.validate.js:679)
    at $.validator.element (jquery.validate.js:466)
    at $.validator.onfocusout (jquery.validate.js:289)
    at HTMLDivElement.delegate (jquery.validate.js:411)
    at HTMLFormElement.dispatch (jquery-2.2.3.js:4737)
    at HTMLFormElement.elemData.handle (jquery-2.2.3.js:4549)
    at Object.trigger (jquery-2.2.3.js:7819)
    at Object.simulate (jquery-2.2.3.js:7890)

Voici la partie rendue du DOM:

    <div class="form-group">
        <label class="control-label" for="Content">Content</label>
        <textarea class="form-control post-content text-box multi-line" id="Content" name="Content" style="display: none;"></textarea>

        <div class="note-editor note-frame panel panel-default">    
            ...summernote generated...
        </div>

        <span class="field-validation-valid text-danger" data-valmsg-for="Content" data-valmsg-replace="true"></span>
    </div>

version jQuery: 2.2.3

jQuery Validate version: 1.16.0

Microsoft.jQuery.Unobtrusive.Validation version: 3.2.3

J'ai fait des recherches et je sais déjà que cela n'a rien à voir avec le plug-in Summernote. J'ai essayé d'exécuter le code suivant à l'intérieur et à l'extérieur du document externe, mais cela n'a pas fonctionné:

$.validator.setDefaults({
            ignore: ":hidden:not(.post-content)"
});

Des idées?

9
Umut Esen

J'utilise ce script pour dire au validateur d'ignorer les éléments Summernote. Il peut être modifié pour ignorer les éléments générés par d'autres éditeurs HTML.

$('form').each(function () {
    if ($(this).data('validator'))
        $(this).data('validator').settings.ignore = ".note-editor *";
});
11
Jeremy Cook

Vous pouvez résoudre l'erreur ci-dessus en modifiant légèrement votre code. 

    var v = $('#myForm').validate({ 
        // exclude it from validation
        ignore: ":hidden:not(#summernote),.note-editable.panel-body"
    });

   var myElement = $('#summernote');

   myElement.summernote({
      // See: http://summernote.org/deep-dive/
      callbacks: {
         onChange: function(contents, $editable) {
          // Note that at this point, the value of the `textarea` is not the same as the one
         // you entered into the summernote editor, so you have to set it yourself to make
         // the validation consistent and in sync with the value.
         myElement.val(myElement.summernote('isEmpty') ? "" : contents);

         // You should re-validate your element after change, because the plugin will have
         // no way to know that the value of your `textarea` has been changed if the change
        // was done programmatically.
       v.element(myElement);
    }
  }
});

Source (officielle): https://github.com/jquery-validation/jquery-validation/issues/1875#issuecomment-272667183

5
Kalpit

J'ai eu le même problème avec Quill (éditeur de texte enrichi) et voici comment je l'ai résolu:

<div id="quillEditor"></div>

var editorForm = $('.rich-text-editor').closest('form');
if (editorForm.data('validator')) {
    // tell jQuery Validate to ignore all child elements of quill
    editorForm.data('validator').settings.ignore = ".ql-container *";
}
1
Hooman Bahreini