jQuery Validate - Enable validation for hidden fields
Asked Answered
R

9

205

In the new version of jQuery validation plugin 1.9 by default validation of hidden fields ignored. I'm using CKEditor for textarea input field and it hides the field and replace it with iframe. The field is there, but validation disabled for hidden fields. With validation plugin version 1.8.1 everything works as expected.

So my question is how to enable validation for hidden fields with v1.9 validation plugin.

This setting doesn't work:

$.validator.setDefaults({ ignore: '' });
Rauch answered 11/12, 2011 at 19:8 Comment(3)
See also #7952681Joann
The link for "validation of hidden fields ignored" is dead.Fridafriday
Validation is working by default for me with <input type="text" name="myfield" id="myfield" required="required" style="display: none;">. I didn't have to change any settings or do anything special.Adulation
G
355

The plugin's author says you should use "square brackets without the quotes", []

http://bassistance.de/2011/10/07/release-validation-plugin-1-9-0/

Release: Validation Plugin 1.9.0: "...Another change should make the setup of forms with hidden elements easier, these are now ignored by default (option “ignore” has “:hidden” now as default). In theory, this could break an existing setup. In the unlikely case that it actually does, you can fix it by setting the ignore-option to “[]” (square brackets without the quotes)."

To change this setting for all forms:

$.validator.setDefaults({ 
    ignore: [],
    // any other default options and/or rules
});

(It is not required that .setDefaults() be within the document.ready function)

OR for one specific form:

$(document).ready(function() {

    $('#myform').validate({
        ignore: [],
        // any other options and/or rules
    });

});

EDIT:

See this answer for how to enable validation on some hidden fields but still ignore others.


EDIT 2:

Before leaving comments that "this does not work", keep in mind that the OP is simply asking about the jQuery Validate plugin and his question has nothing to do with how ASP.NET, MVC, or any other Microsoft framework can alter this plugin's normal expected behavior. If you're using a Microsoft framework, the default functioning of the jQuery Validate plugin is over-written by Microsoft's unobtrusive-validation plugin.

If you're struggling with the unobtrusive-validation plugin, then please refer to this answer instead: https://mcmap.net/q/48988/-jquery-validate-enable-validation-for-hidden-fields

Grater answered 19/12, 2011 at 18:34 Comment(12)
Maybe the down-voter can give me some constructive feedback. Otherwise, the answer is fully self-contained, properly sourced, gives code examples, and is technically correct as per the plugin's author.Grater
Note that setDefaults must also be called within $(document).ready(function() { }) in order to workKismet
@StijnVanBael, no, that is false. See: jsfiddle.net/F4w92/1 and also see my second comment on jerick's answer.Grater
Well, it did not work for me until I put it inside $(document).ready. I'll try to find out why.Kismet
Well said @Sparky. The down-votes are probably kind of revenge, I've encountered the same..Orose
The JSFiddle doesn't work anymore because the libraries are loaded in HTTP instead of HTTPS. Updated version : jsfiddle.net/F4w92/31Elbow
I downvoted also as this does not work for me using latest version, had to use: $("form").data("validator").settings.ignore = ""; as other answer from @James bellowAstarte
@MarkHomer, see the latest edits on my answer above. My answer exactly and correctly addresses only the OP and has nothing to do with how Microsoft's unobtrusive-validation plugin will interfere with the normal functioning of jQuery Validate.Grater
@Grater OK fair enough have changed to an up vote the EDIT 2 you have added helps now.Astarte
How do I validate just one specific hidden field but still ignore others?Sauers
@3zzy, that's specifically addressed in the first EDIT above: "how to enable validation on some hidden fields but still ignore others"Grater
Thank you @Sparky, I have a similar problem and while the solution in your post works to trigger validation when the form is initially submitted, it does not work post-submission (i.e. it does not eagerly validate changes to the input after the form has been submitted). Here is my question, I would be grateful for your help as I'm new to web development and unsure of how to go about troubleshooting this.Fadiman
C
83

This worked for me, within an ASP.NET MVC3 site where I'd left the framework to setup unobtrusive validation etc., in case it's useful to anyone:

$("form").data("validator").settings.ignore = "";
Comer answered 15/6, 2012 at 15:1 Comment(6)
I also like this one since it means I can do it in certain circumstances, rather than changing the default behaviour.Rhetoric
I had to do it this way, because using .validate() to change the options wasn't working.Radford
this is the correct solution for the unobtrusive validation, I tried all the other solutions, they could work in case NOT using unobtrusive. If you are using unobtrusive here is right place.Nympha
Had to use this method also for unobtrusive validation to work with Bootstrap AccordionSamul
When I change it to this the form is not validated. I use unobtrusive .net coreDistil
This is still the right solution for .net core 3.1 and unobtrusive validation... Thanks again.Sheriff
C
69

Make sure to put

 $.validator.setDefaults({ ignore: '' });

NOT inside $(document).ready

Crasis answered 8/4, 2012 at 14:5 Comment(8)
Excellent answer. A link to the documentation is good for people to learn, but a straight up answer is more valuable imo. He OP was on the right track, but putting it outside of $(document).ready is the trick.Nace
@KevinZych, Apparently, it makes absolutely no difference whether $.validator.setDefaults() is placed inside or outside of the DOM ready hander. Compare this jsFiddle to this jsFiddle.Grater
Interesting @Sparky, your fiddles are excellent proof. I'd have to go back and look at the code I fixed using this solution and find out why I came to the conclusion that it had to be inside of the DOM ready handler. Must have been some other reason.Nace
Justin explains why running inside doc ready causes problems. However, this answer is not a good option because it's hard to guarantee that something outside doc ready will run BEFORE doc ready. Doc.ready will not wait for scripts outside of it to run. Nothing personal, but this isn't a reliable answer.Husk
Finally I have a answer..Thank you so muchInvoke
This saved me! I played with this for too long when all I needed to do was move it outside of document.readyMilch
I've been struggling with this for sometime now and this gave me the answer! Thanks! To add, I added this inside my $(document).ready and it worked perfect! Thanks again!!Keating
Worked for me, having it outside the dom.ready, right after including the js validator script! Still don't know why!Voiceless
Z
31

So I'm going to go a bit deeper in to why this doesn't work because I'm the kind of person that can't sleep at night without knowing haha. I'm using jQuery validate 1.10 and Microsoft jQuery Unobtrusive Validation 2.0.20710.0 which was published on 1/29/2013.

I started by searching for the setDefaults method in jQuery Validate and found it on line 261 of the unminified file. All this function really does is merge your json settings in to the existing $.validator.defaults which are initialized with the ignore property being set to ":hidden" along with the other defaults defined in jQuery Validate. So at this point we've overridden ignore. Now let's see where this defaults property is being referenced at.

When I traced through the code to see where $.validator.defaults is being referenced. I noticed that is was only being used by the constructor for a form validator, line 170 in jQuery validate unminified file.

// constructor for validator
$.validator = function( options, form ) {
    this.settings = $.extend( true, {}, $.validator.defaults, options );
    this.currentForm = form;
    this.init();
};

At this point a validator will merge any default settings that were set and attach it to the form validator. When you look at the code that is doing the validating, highlighting, unhighlighting, etc they all use the validator.settings object to pull the ignore property. So we need to make sure if we are to set the ignore with the setDefaults method then it has to occur before the $("form").validate() is called.

If you're using Asp.net MVC and the unobtrusive plugin, then you'll realize after looking at the javascript that validate is called in document.ready. I've also called my setDefaults in the document.ready block which is going to execute after the scripts, jquery validate and unobtrusive because I've defined those scripts in the html before the one that has the call in it. So my call obviously had no impact on the default functionality of skipping hidden elements during validation. There is a couple of options here.

Option 1 - You could as Juan Mellado pointed out have the call outside of the document.ready which would execute as soon as the script has been loaded. I'm not sure about the timing of this since browsers are now capable of doing parallel script loading. If I'm just being over cautious then please correct me. Also, there's probably ways around this but for my needs I did not go down this path.

Option 2a - The safe bet in my eyes is to just replace the $.validator.setDefaults({ ignore: '' }); inside of the document.ready event with $("form").data("validator").settings.ignore = "";. This will modify the ignore property that is actually used by jQuery validate when doing each validation on your elements for the given form.

Options 2b - After looking in to the code a bit more you could also use $("form").validate().settings.ignore = ""; as a way of setting the ignore property. The reason is that when looking at the validate function it checks to see if a validator object has already been stored for the form element via the $.data() function. If it finds a validator object stored with the form element then it just returns the validator object instead of creating another one.

Zebadiah answered 29/1, 2013 at 3:3 Comment(2)
Good work as the OP answer didn't work for me in MVC 5Astarte
your analysis helped me a lot in fixing one my validation issues. +1Unclasp
P
18

This worked for me within an ASP.NET site. To enable validation on some hidden fields use this code

$("form").data("validator").settings.ignore = ":hidden:not(#myitem)";

To enable validation for all elements of form use this one $("form").data("validator").settings.ignore = "";

Note that use them within $(document).ready(function() { })

Peeress answered 10/6, 2016 at 6:19 Comment(0)
M
9

Just added ignore: [] in the specific page for the specific form, this solution worked for me.

$("#form_name").validate({
        ignore: [],
        onkeyup: false,
        rules: {            
        },      
        highlight:false,
    });
Myrtlemyrvyn answered 27/11, 2013 at 4:58 Comment(0)
P
2

This is working for me.

jQuery("#form_name").validate().settings.ignore = "";
Potence answered 16/1, 2017 at 2:32 Comment(0)
P
0

The validation was working for me on form submission, but it wasn't doing the reactive event driven validation on input to the chosen select lists.

To fix this I added the following to manually trigger the jquery validation event that gets added by the library:

$(".chosen-select").each(function() {
  $(this).chosen().on("change", function() {
    $(this).parents(".form-group").find("select.form-control").trigger("focusout.validate");
  });
});

jquery.validate will now add the .valid class to the underlying select list.

Caveat: This does require a consistent html pattern for your form inputs. In my case, each input filed is wrapped in a div.form-group, and each input has .form-control.

Picco answered 3/4, 2020 at 23:51 Comment(0)
G
-17

Just find the text ignore: ":hidden" in your jquery validation file and comment it. After comment this it will never loss any hidden elements to validate...

Thanks

Gonfalon answered 20/6, 2013 at 12:29 Comment(1)
Never a good idea to just randomly comment out code in a third party library.Springhalt

© 2022 - 2024 — McMap. All rights reserved.