[英]conflicting focus on two fields inside the ajax success function used for validation
我已经使用ajax对场模糊进行验证(焦点如果无效),但它与下一个字段的ajax验证冲突
1.Tried设置一个全局变量并在下一个字段验证中检查它。 2.在变量中存储$(this),并在绑定方法上调用事件。 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 = "";
}
}
});
}
}
});
如果字段上的值无效,则字段应保持聚焦,而不是保留字段,直到输入正确的值。
通过在ajax问题中设置(async:false)来解决问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.