下面我们看一个常见的异步表单校验(校验工号在后台是否存在,存在为有效工号)
var BASE_PATH = '${rc.contextPath}';var $workerIdInput = $('#workerIdInput');var $workerIdError = $('#workerIdError');//标识用户输入的工号是否正确var isWorkerIdCorrect = false;var ERROR_WORKER_ID_IS_NULL = "员工工号不能为空";var ERROR_WORKER_ID_IS_NOT_CORRECT = "请输入有效的员工工号";//显示错误信息function showWorkerIdError(errorMessage) {  $workerIdError.html(errorMessage);  $workerIdError.show();}//隐藏错误信息$workerIdInput.on('keydown', function() {  $workerIdError.hide();});//将上次输入的工号保存起来$workerIdInput.on('focus', function() {  var workerId = $.trim($(this).val());  $(this).data('before', workerId);});//blur时进行校验$workerIdInput.on('blur', function() {  var workerId = $.trim($(this).val());  //长度为0时,显示工号为空的错误信息  if (!workerId.length) {    showWorkerIdError(ERROR_WORKER_ID_IS_NULL);    return false;  }  //若用户当前输入的数据和上次输入的数据一样,则不调用后台接口  //假设用户输入123456,调用后台接口,返回结果为,不正确的工号  //用户将输入内容进行更改后,仍然为123456,则校验程序不会访问网络,直接显示错误信息  if (workerId == $(this).data('before')) {    if (!isWorkerIdCorrect) {      showWorkerIdError(ERROR_WORKER_ID_IS_NOT_CORRECT);    }    return false;  }  //调用后台接口,查询此员工id是否正确  checkWorkerIdExists(workerId, function(data) {    isWorkerIdCorrect = data.isWorkerIdExists;    if (!isWorkerIdCorrect) {      showWorkerIdError(ERROR_WORKER_ID_IS_NOT_CORRECT);    }  });});function checkWorkerIdExists(workerId, callback) {  $.Ajax({    url: BASE_PATH + '/forgotPwd/checkWorkerIdExists.htm',    data: {      workerId: workerId    },    success: callback  });}$workerIdForm.on('submit', function() {  //只有服务器返回为true的时候,我们的表单才能提交  if (!isWorkerIdCorrect) {    $workerIdInput.focus();    return false;  }});上述代码写完,一个输入框的验证基本上搞定了。
isWorkerIdCorrect为false,只有服务器校验成功才为true下面是修改后的代码:
var BASE_PATH = '${rc.contextPath}';var $workerIdInput = $('#workerIdInput');var $workerIdError = $('#workerIdError');//标识用户输入的工号是否正确var isWorkerIdCorrect = false;//标识后台校验工号是否已完成(true: 为校验中, false: 校验没开始或已结束)var isWorkerIdLoading = false;//标识用户是否提交了表单var isSubmit = false;var ERROR_WORKER_ID_IS_NULL = "员工工号不能为空";var ERROR_WORKER_ID_IS_NOT_CORRECT = "请输入有效的员工工号";//显示错误信息function showWorkerIdError(errorMessage) {  $workerIdError.html(errorMessage);  $workerIdError.show();}//隐藏错误信息$workerIdInput.on('keydown', function() {  $workerIdError.hide();});//将上次输入的工号保存起来$workerIdInput.on('focus', function() {  var workerId = $.trim($(this).val());  $(this).data('before', workerId);});//blur时进行校验$workerIdInput.on('blur', function() {  var workerId = $.trim($(this).val());  //长度为0时,显示工号为空的错误信息  if (!workerId.length) {    showWorkerIdError(ERROR_WORKER_ID_IS_NULL);    return false;  }  //若用户当前输入的数据和上次输入的数据一样,则不调用后台接口  //假设用户输入123456,调用后台接口,返回结果为,不正确的工号  //用户将输入内容进行更改后,仍然为123456,则校验程序不会访问网络,直接显示错误信息  if (workerId == $(this).data('before')) {    if (!isWorkerIdCorrect) {      showWorkerIdError(ERROR_WORKER_ID_IS_NOT_CORRECT);    }    return false;  }  //调用后台接口,查询此员工id是否存在  checkWorkerIdExists(workerId, function(data) {    isWorkerIdCorrect = data.isWorkerIdExists;    if (!isWorkerIdCorrect) {      showWorkerIdError(ERROR_WORKER_ID_IS_NOT_CORRECT);    }  });});function checkWorkerIdExists(workerId, callback) {  $.ajax({    url: BASE_PATH + '/forgotPwd/checkWorkerIdExists.htm',    data: {      workerId: workerId    },    beforeSend: function() {      //发送请求前,标识正在校验工号      isWorkerIdLoading = true;    },    success: callback,    complete: function() {      //结束后,关闭标识      isWorkerIdLoading = false;      //在后台校验数据过程中,用户若提交了表单,则在此自动提交      if (isSubmit) {        $workerIdForm.submit();      }    }  });}//回车提交表单$workerIdInput.on('keyPRess', function(e) {  if (e.which === 13) {    $(this).blur();    $workerIdForm.submit();  }});$workerIdForm.on('submit', function() {  //若正在后台校验工号,则标识用户提交了表单  if (isWorkerIdLoading) {    isSubmit = true;    return false;  }  if (!isWorkerIdCorrect) {    $workerIdInput.focus();    return false;  }});最终效果,图中2个输入框均为异步校验,但效果看起来和同步的一样。图中使用了gprs网络模拟网速较慢的情况

新闻热点
疑难解答