【发布时间】:2013-05-29 06:29:01
【问题描述】:
我正在使用 jquery validate.js 在我的 jquery 移动应用程序中验证我的联系表单。 当我通过 url 加载页面或页面刷新时,验证似乎工作得很好。 但是当我从另一个刷新的页面链接返回联系表单时,验证将停止工作。
刷新页面时它可以工作。 我尝试了以下方法:
1) 包括 jquery mobile js 之前的contact.js。
2)data-ajax="false";
3) 使用bind
$(document).bind("mobileinit", function(){
$.extend( $.mobile , { ajaxEnabled: false });
});
4) refresh form page with jQuery Mobile
5) 使用window.onload
window.onload = function() {
if(!window.location.hash) {
window.location = window.location + '#loaded';
window.location.reload();
}
}
5)Jquery-Mobile: How to reload/refresh the internal page
6) One time page refresh after first page load Javascript working only on page refresh in jQuery mobile
但是这些都不起作用。我需要做的是在导航到页面时刷新页面一次。 这是我使用 jquery mobile 的联系表单代码。
<form method="post" action="" id="feedback" name="feedback">
<input type="text" name="user_name" data-role="none" id="name" value="" placeholder= "Your name*" />
<br />
<input class="email" required="true" type="text" name="user_email" data-role="none" id="email" value="" placeholder="Your Email*" />
<br />
<textarea cols="70" rows="12" class="required" name="user_message" id="c_message" data-role="none" placeholder="Your message*">
</textarea>
<br />
<input type="submit" value="Send" data-mini="true" data-role="none" data-inline="true" class="green_like" id="send" />
</form>
这是位于“联系我们”表单中的 JS 代码。
$(document).bind("pageinit",function(){
$("#feedback").validate({
submitHandler : function() {
$.ajax({
type:'POST',
url :'/some/url',
data: $('#feedback').serialize(),
success: function(resp) {
if(resp==1)
{
$("#success_post_contact").html('<label style="color:green;margin-left: 6px;" >Thank you for contacting us.</label>');
}
}
});//end of ajax
}//end of submit handler
});//end of validate
});//end of document.bind
【问题讨论】:
标签: javascript jquery jquery-mobile