繁体   English   中英

关注用于验证的ajax成功函数内的两个字段

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM