亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript將異步校驗表單改寫為同步表單

2019-11-20 13:19:15
字體:
來源:轉載
供稿:網友

同步表單校驗的缺點

響應錯誤信息時,需要重新加載整個頁面(雖然有緩存,客戶端仍然需要通過http協議對比每個文件是否有更新,以保持文件最新)
服務器響應錯誤以后,用戶之前所輸入的信息全部丟失了,用戶需要從頭開始填寫(部分瀏覽器幫我們緩存了這些數據)

異步校驗表單的初衷

提升用戶體驗
最大化減少網絡請求,減輕服務器壓力
下面我們看一個常見的異步表單校驗(校驗工號在后臺是否存在,存在為有效工號)

校驗工號

復制代碼 代碼如下:

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;
  }
});

上述代碼寫完,一個輸入框的驗證基本上搞定了。

我覺得還有影響用戶體驗的地方
還不支持回車操作,oh my god,回車也要能提交表單
若用戶網速較慢,點擊提交按鈕,會沒有任何反映,因為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網絡模擬網速較慢的情況

效果圖

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
啊v视频在线一区二区三区| 国产成人一区二区| 在线播放国产一区中文字幕剧情欧美| 国产在线不卡精品| 日韩精品电影网| 欧美精品videos另类日本| 色偷偷偷亚洲综合网另类| 亚洲色在线视频| 久久99久久亚洲国产| 国产自产女人91一区在线观看| 国产主播精品在线| 久久伊人色综合| 亚洲成av人影院在线观看| 亚洲大胆人体视频| 日韩av电影在线播放| 日韩视频在线免费| 久久99热精品这里久久精品| 操日韩av在线电影| 欧美日韩国产va另类| 欧美在线一区二区三区四| 尤物精品国产第一福利三区| 91亚洲精品在线| 欧美极度另类性三渗透| 国产精品xxxxx| 日韩成人在线免费观看| 久久综合九色九九| 日韩网站在线观看| 亚洲精品国产精品久久清纯直播| 国产精品亚洲美女av网站| 欧美一区二区大胆人体摄影专业网站| 久久久久久国产三级电影| 91亚洲va在线va天堂va国| 国产精品美女主播在线观看纯欲| 国产精品成人一区二区三区吃奶| 亚洲欧美国产精品久久久久久久| 成人激情在线观看| 国产精品永久免费视频| 国产中文字幕91| 成人444kkkk在线观看| 午夜精品福利电影| 亚洲人线精品午夜| 国产精品爽爽爽| 欧美日韩另类字幕中文| 日韩精品免费一线在线观看| 国产精品久久久久久久天堂| 91精品国产综合久久香蕉922| 亚洲人免费视频| 一区二区国产精品视频| 亚洲xxxx18| 亚洲精品一区av在线播放| 91免费看视频.| 亚洲免费成人av电影| 在线看片第一页欧美| 日韩精品久久久久| 欧美丰满老妇厨房牲生活| 亚洲成人网在线| 欧美激情视频网| 精品亚洲一区二区三区在线观看| 欧美激情一区二区三区在线视频观看| 国产精品日韩欧美综合| 久久国产精品久久久久久久久久| 久久人人97超碰精品888| 国产精品自产拍在线观| 久久精品成人动漫| 国产精品麻豆va在线播放| 国产精品久久久久久久电影| 精品动漫一区二区三区| 久久久久成人精品| 日韩欧中文字幕| 日韩电影中文字幕在线| 久久精品中文字幕免费mv| 欧美成人激情视频免费观看| 2019日本中文字幕| 国产精品网站入口| 久久久91精品国产一区不卡| 久久偷看各类女兵18女厕嘘嘘| 热re99久久精品国产66热| 在线日韩第一页| 日本午夜精品理论片a级appf发布| 亚洲欧洲偷拍精品| 日本久久亚洲电影| 成人国内精品久久久久一区| 欧美日本精品在线| 国产精品va在线播放| 亚洲偷熟乱区亚洲香蕉av| 精品色蜜蜜精品视频在线观看| 欧美在线免费视频| 最近2019年中文视频免费在线观看| 中文字幕v亚洲ⅴv天堂| 亚洲www在线观看| 欧美另类交人妖| 日韩电影免费在线观看| 亚洲人成亚洲人成在线观看| 国模视频一区二区三区| 日韩在线观看免费| 精品在线小视频| 亚洲国产成人精品电影| 不卡中文字幕av| 精品国产一区二区三区久久狼黑人| 久久频这里精品99香蕉| 日韩av影片在线观看| 91精品国产自产在线| 亚洲精品456在线播放狼人| 亚洲天堂av在线免费观看| 国产精品久久久久91| 亚洲va电影大全| 日韩视频永久免费观看| 日本不卡视频在线播放| 亚洲色图18p| 欧美性视频在线| 一区二区亚洲精品国产| 国产精品大陆在线观看| 成人精品久久av网站| 色播久久人人爽人人爽人人片视av| 国产精品九九久久久久久久| 国产精品久久久久99| 国产精品揄拍500视频| 蜜月aⅴ免费一区二区三区| 91视频88av| 国产精品久久电影观看| 国产精品视频区1| 欧美日韩中文字幕在线视频| 国产不卡一区二区在线播放| 国产精品福利无圣光在线一区| 77777少妇光屁股久久一区| 色与欲影视天天看综合网| 国产成人欧美在线观看| 亚洲色图欧美制服丝袜另类第一页| 日韩欧美在线第一页| 欧美精品少妇videofree| 深夜福利91大全| 91极品女神在线| 欧美插天视频在线播放| 欧美成人h版在线观看| 国内精久久久久久久久久人| 精品视频9999| www国产精品视频| 韩曰欧美视频免费观看| 日韩av在线精品| 亚洲欧美日韩精品久久亚洲区| 久久这里只有精品99| 欧美在线观看视频| 久久精品国产久精国产思思| 日韩成人在线视频观看| 欧美日韩一区二区在线播放| 在线丨暗呦小u女国产精品| 精品国内产的精品视频在线观看| 国产精品久久一区主播| 午夜精品三级视频福利| 久久国产色av| 国产精品青草久久久久福利99| 少妇久久久久久| 欧美视频在线观看免费| 亚洲欧美国产va在线影院| 97香蕉超级碰碰久久免费软件| 97精品免费视频| 国产日韩欧美视频| 欧美大片欧美激情性色a∨久久| 久久综合88中文色鬼| 国产精品久久久久久久电影| 黄色成人在线免费| 97精品欧美一区二区三区| 欧美日韩中文字幕日韩欧美| 亚洲欧美在线第一页|