I am currently facing a problem with validation after dynamically adding content.
I have a view strongly typed to a model (Order
). This Order can have m
Ok, I am going to start over with a new answer here.
Before you call $.validator.unobtrusive.parse
, remove the original validator and unobtrusive validation from the form like so:
var form = $("#main_div").closest("form");
form.removeData('validator');
form.removeData('unobtrusiveValidation');
$.validator.unobtrusive.parse(form);
This same answer is documented here.
What worked for me was to re-apply the validator after the call to load the partial view. In my case, I'm using $.post().then()
but you could do something similar with a .always()
callback of an AJAX call.
$.post(url, model, function (data) {
//load the partial view
$("#Partial").html(data);
}).then(function () {
$("form").each(function () { $.data($(this)[0], 'validator', false); });
$.validator.unobtrusive.parse("form");
});