我使用这个jquery代码进行无限循环,我知道为什么,但我不知道如何解决这个问题:
<form id="submitme">
<input value="" name="n1" id="n1" type="text"/>
<input value="Send" type="button"/>
</form>
<script>
$('#submitme').bind( 'submit', function() {
$.post( 'validate.php', 'value=' + $('#n1').val(), function (data) {
if (data == "true")
$('#submitme').submit();
});
});
</script>
答案 0 :(得分:3)
jQuery.validate插件可以解决此问题,我强烈建议您使用它:
$('#submitme').validate({
rules: {
n1: {
remote: {
url: 'validate.php',
type: 'post'
}
}
}
});
但是如果你不想使用它,另一种可能性就是使用全局变量,如下所示:
$('#submitme').submit(function() {
if (!$.formSubmitting) {
var $form = $(this);
$.post('validate.php', { value: $('#n1').val() }, function (data) {
if (data == 'true') {
// set the global variable to true so that we don't enter
// the infinite loop and directly submit the form
$.formSubmitting = true;
$form.submit();
}
});
return false;
}
return true;
});
请注意:您放置在表单中的按钮不是提交按钮,因此单击它不会触发submit
处理程序。你应该把它变成一个提交按钮:
<input value="Send" type="submit" />
答案 1 :(得分:0)
我不是jQuery专家,但是在Prototype中,当你为一个动作编写一个事件处理程序并且你没有停止默认动作时,它将在你完成所有回调功能之后执行。因此,只需翻转if-else语句,您就应该能够避免无限循环:
$('#submitme').bind( 'submit', function(event) {
$.post( 'validate.php', 'value=' + $('#n1').val(), function (data) {
if (data != "true")
// if validation has failed, prevent default action (submit)
event.preventDefault();
});
// if default action was not prevented it will be executed
})
答案 2 :(得分:0)
我找到了这个解决方案:
<form id="submitme">
<input value="" name="n1" id="n1" type="text"/>
<input value="Send" type="button"/>
</form>
<script>
$('#submitme').bind( 'submit', function() {
if ($.data( $('#submitme' ), 'validated'))
return true;
$.post( 'validate.php', 'value=' + $('#n1').val(), function (data) {
if (data == "true") {
$.data( $('#submitme'), 'validated', true );
$('#submitme').submit();
}
});
return false;
});
</script>