我已经使用ajax验证了场模糊(如果无效,则聚焦),但是与下一个字段的ajax验证冲突
1。尝试设置一个全局变量并在下一个字段验证中对其进行检查。 2.将$(this)存储在变量中,在bind方法上也称为event。 3.尝试在焦点位于当前字段但在某些条件下不起作用时禁用其他字段。
$('input[name="ledgercode"]')
.bind(
'blur',
'#ledgercode',
function(e) {
if ($('#dialog1').dialog('isOpen')) {
e.preventDefault();
} else {
$this = $(this);
var ledgercd = $(this).val();
if (ledgercd == "") {
document.getElementById("msgbox1").innerHTML = "Code must be entered";
$(this).focus();
} else {
$.ajax({
type : 'POST',
url : 'GL_Servlet?method=ledger_validation',
dataType : 'json',
data : {
"json" : [ ledgercd,company ]
},
success : function(data) {
var ldgstat = (data.ldgstat);
if (ldgstat == false) {
$this.focus(); //consistent focus if value invalid
document.getElementById("msgbox1").innerHTML = "Invalid Code";
} else if (data.ldgstat == true) {
$('#txt_ldg_name').val(data.ldg_desc);
$this.closest("tr")
.find('input[name="ldg_desc"]').val(data.ldg_desc);
document.getElementById("msgbox1").innerHTML = "";
}
}
});
}
}
});
如果字段值无效,则该字段应保持焦点状态,直到输入正确的值后才离开该字段。
答案 0 :(得分:0)
通过解决ajax问题中的设置(异步:false,)。