在用于验证的ajax成功函数内的两个字段上的焦点冲突

时间:2019-05-28 08:19:00

标签: javascript ajax

我已经使用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 = "";
}
    }                                            
   });
}
}
   });

如果字段值无效,则该字段应保持焦点状态,直到输入正确的值后才离开该字段。

1 个答案:

答案 0 :(得分:0)

通过解决ajax问题中的设置(异步:false,)。