jquery validate не работает с динамическим контентом
jquery validate не работает с динамическим контентом
Я использую jquery для создания вкладок с новым контентом.
var tabCounter = 2,
tabTemplate = "<li><a href='#{href}'>#{label}</a> <span class='ui-icon ui-icon- close'>Remove Tab</span></li>";
var tabs = $( "#tabs" ).tabs();
var tabContentHtml = $("#tabs-1").html();
Добавить новые вкладки при нажатии кнопки
$("#add_tab").click(function(){
addTab();
});
function addTab() {
var label = "Tab " + tabCounter,
id = "tabs-" + tabCounter,
li = $( tabTemplate.replace( /#\{href\}/g, "#" + id ).replace( /#\{label\}/g, label ) );
tabs.find( ".ui-tabs-nav" ).append( li );
tabs.append( "<div id='" + id + "'><p>" + tabContentHtml + "</p></div>" );
tabs.tabs( "refresh" );
tabCounter++;
}
Проверьте форму на вкладках. Он работает с вкладками-1, но не работает с вкладками-2
$("#Form").validate({
rules:{
name: "required",
messages:{
name: "Please enter your name"
},
errorElement: "div",
wrapper: "div",
errorPlacement: function(error, element) {
offset = element.offset();
error.insertBefore(element)
error.addClass('message'); // add a class to the wrapper
error.css('position', 'absolute');
error.css('left', offset.left + element.outerWidth());
},
submitHandler: function(form) {
form.submit();
}
});
Код HTML
<form id="Form" method="post" action="">
<div id="tabs">
<ul>
<li>
<a href="#tabs-1">Visa 1</a>
<!-- <span class="ui-icon ui-icon-close">Remove Tab</span> -->
</li>
</ul>
<div id="tabs-1">
<table class="content-tabs">
<tr class="fieldgroup">
<td>Full Name</td>
<td><input type="text" class="txtName" name="name"></td>
</tr>
<tr></td colspan="2"><input type="submit" value="submit" /></td></tr>
</table>
</div>
</div>
</form>
Как проверить содержимое вкладок-2?
2 ответа
Когда вы добавляете новую вкладку, вам нужно вручную добавить правила для проверки нового контента. Возможно, самый простой способ - это использовать метод правил плагина проверки.
В нижней части вашего addTab
функция, вы бы сделали что-то вроде этого:
$('#'+id).find('input').rules('add',{
required: true
});
Проблема может быть в том, что jquery не знает об обновлении dom, если вы не используете live или методы
попробуйте поставить метод validate для метода "on", например
$("#Form").on ('click',handler)
Пожалуйста, примите ответ, как предложил Лоуренс
ставь вот так
$("#Form").on("click", function(event){
$(this).validate({
rules:{
name: "required",
messages:{
name: "Please enter your name"
},
errorElement: "div",
wrapper: "div",
errorPlacement: function(error, element) {
offset = element.offset();
error.insertBefore(element)
error.addClass('message'); // add a class to the wrapper
error.css('position', 'absolute');
error.css('left', offset.left + element.outerWidth());
},
submitHandler: function(form) {
form.submit();
}
});
});