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

首頁 > 開發 > AJAX > 正文

自己編寫的支持Ajax驗證的JS表單驗證插件

2024-09-01 08:33:30
字體:
來源:轉載
供稿:網友

創建一個JavaScript表單驗證插件,可以說是一個繁瑣的過程,涉及到初期設計、開發與測試等等環節。實際上一個優秀的程序員不僅是技術高手,也應該是善假于外物的。本文介紹的這個不錯的JavaScript表單驗證插件,支持ajax驗證,有需要的小伙伴可以參考下

自己編寫了一個表單驗證插件,支持ajax驗證,使用起來很簡單。

每個需要驗證的表單元素下面有一個span標簽,這個標簽的class有一個valid表示需要驗證,如果有nullable則表示可為空;rule表示驗證規則,msg表示錯誤提示信息;to表示要驗證的元素的name值,如果元素是單個的,to可以不寫。該插件會遍歷每個有valid的span標簽,找出它前面需要驗證的元素,根據rule驗證,如果驗證不通過,則顯示邊框為紅色,鼠標放在元素上時顯示錯誤信息。

驗證時機:1、點擊提交按鈕時顯式調用驗證方法;2、當元素觸發blur時驗證。

插件代碼:

CSS:

 

 
  1. .failvalid 
  2. border: solid 2px red !important; 

JS:

 

 
  1. /** 
  2. * suxiang 
  3. * 2014年12月22日 
  4. * 驗證插件 
  5. */ 
  6.  
  7. SimpoValidate = { 
  8. //驗證規則 
  9. rules: { 
  10. int: /^[1-9]/d*$/, 
  11. number: /^[+-]?/d*/.?/d+$/ 
  12. }, 
  13.  
  14. //初始化 
  15. init: function () { 
  16. $(".valid").each(function () { //遍歷span 
  17. if ($(this)[0].tagName.toLowerCase() == "span") { 
  18. var validSpan = $(this); 
  19. var to = validSpan.attr("to"); 
  20. var target; 
  21. if (to) { 
  22. target = $("input[name='" + to + "'],select[name='" + to + "'],textarea[name='" + to + "']"); 
  23. else { 
  24. var target = validSpan.prev(); 
  25. if (target) { 
  26. target.blur(function () { 
  27. SimpoValidate.validOne(target, validSpan); 
  28. }); 
  29. }); 
  30. }, 
  31.  
  32. //驗證全部,驗證成功返回true 
  33. valid: function () { 
  34. SimpoValidate.ajaxCheckResult = true
  35. var bl = true
  36.  
  37. $(".valid").each(function () { //遍歷span 
  38. if ($(this)[0].tagName.toLowerCase() == "span") { 
  39. var validSpan = $(this); 
  40. var to = validSpan.attr("to"); 
  41. var target; 
  42. if (to) { 
  43. target = $("input[name='" + to + "'],select[name='" + to + "'],textarea[name='" + to + "']"); 
  44. else { 
  45. target = validSpan.prev(); 
  46. if (target) { 
  47. if (!SimpoValidate.validOne(target, validSpan)) { 
  48. bl = false
  49. }); 
  50.  
  51. return bl && SimpoValidate.ajaxCheckResult; 
  52. }, 
  53.  
  54. //單個驗證,驗證成功返回true 
  55. validOne: function (target, validSpan) { 
  56. SimpoValidate.removehilight(target, msg); 
  57.  
  58. var rule = SimpoValidate.getRule(validSpan); 
  59. var msg = validSpan.attr("msg"); 
  60. var nullable = validSpan.attr("class").indexOf("nullable") == -1 ? false : true//是否可為空 
  61. var to = validSpan.attr("to"); 
  62. var ajaxAction = validSpan.attr("ajaxAction"); 
  63.  
  64. if (target) { 
  65. //checkbox或radio 
  66. if (target[0].tagName.toLowerCase() == "input" && target.attr("type") && (target.attr("type").toLowerCase() == "checkbox" || target.attr("type").toLowerCase() == "radio")) { 
  67. var checkedInput = $("input[name='" + to + "']:checked"); 
  68. if (!nullable) { 
  69. if (checkedInput.length == 0) { 
  70. SimpoValidate.hilight(target, msg); 
  71. return false
  72.  
  73. //input或select 
  74. if (target[0].tagName.toLowerCase() == "input" || target[0].tagName.toLowerCase() == "select") { 
  75. var val = target.val(); 
  76. if (!nullable) { 
  77. if ($.trim(val) == "") { 
  78. SimpoValidate.hilight(target, msg); 
  79. return false
  80. else { 
  81. if ($.trim(val) == "") { 
  82. SimpoValidate.removehilight(target, msg); 
  83. return true
  84.  
  85. if (rule) { 
  86. var reg = new RegExp(rule); 
  87. if (!reg.test(val)) { 
  88. SimpoValidate.hilight(target, msg); 
  89. return false
  90.  
  91. if (ajaxAction) { 
  92. SimpoValidate.ajaxCheck(target, val, ajaxAction); 
  93. else if (target[0].tagName.toLowerCase() == "textarea") { 
  94. var val = target.text(); 
  95. if (!nullable) { 
  96. if ($.trim(val) == "") { 
  97. SimpoValidate.hilight(target, msg); 
  98. return false
  99. else { 
  100. if ($.trim(val) == "") { 
  101. SimpoValidate.removehilight(target, msg); 
  102. return true
  103.  
  104. if (rule) { 
  105. var reg = new RegExp(rule); 
  106. if (!reg.test(val)) { 
  107. SimpoValidate.hilight(target, msg); 
  108. return false
  109.  
  110. if (ajaxAction) { 
  111. SimpoValidate.ajaxCheck(target, val, ajaxAction); 
  112.  
  113. return true
  114. }, 
  115.  
  116. ajaxCheckResult: true
  117.  
  118. ajaxCheck: function (target, value, ajaxAction) { 
  119. var targetName = target.attr("name"); 
  120. var data = new Object(); 
  121. data[targetName] = value; 
  122.  
  123. $.ajax({ 
  124. url: ajaxAction, 
  125. type: "POST"
  126. data: data, 
  127. async: false
  128. success: function (data) { 
  129. if (data.data == true) { 
  130. SimpoValidate.removehilight(target); 
  131. else { 
  132. SimpoValidate.ajaxCheckResult = false
  133. SimpoValidate.hilight(target, data.data); 
  134. }); 
  135. }, 
  136.  
  137. //獲取驗證規則 
  138. getRule: function (validSpan) { 
  139. var rule = validSpan.attr("rule"); 
  140. switch ($.trim(rule)) { 
  141. case "int"
  142. return this.rules.int
  143. case "number"
  144. return this.rules.number; 
  145. default
  146. return rule; 
  147. break
  148. }, 
  149.  
  150. //紅邊框及錯誤提示 
  151. hilight: function (target, msg) { 
  152. target.addClass("failvalid"); 
  153. target.bind("mouseover"function (e) { 
  154. SimpoValidate.tips(target, msg, e); 
  155. }); 
  156. target.bind("mouseout"function () { 
  157. SimpoValidate.removetips(); 
  158. }); 
  159. }, 
  160.  
  161. //取消紅邊框及錯誤提示 
  162. removehilight: function (target) { 
  163. target.unbind("mouseover"); 
  164. target.unbind("mouseout"); 
  165. target.removeClass("failvalid"); 
  166. SimpoValidate.removetips(); 
  167. }, 
  168.  
  169. //顯示提示 
  170. tips: function (target, text, e) { 
  171. var divtipsstyle = "position: absolute; z-index:99999; left: 0; top: 0; background-color: #dceaf2; padding: 3px; border: solid 1px #6dbde4; visibility: hidden; line-height:20px; font-size:12px;"
  172. $("body").append("<div class='div-tips' style='" + divtipsstyle + "'>" + text + "</div>"); 
  173.  
  174. var divtips = $(".div-tips"); 
  175. divtips.css("visibility""visible"); 
  176.  
  177. var top = e.clientY + $(window).scrollTop() - divtips.height() - 18; 
  178. var left = e.clientX; 
  179. divtips.css("top", top); 
  180. divtips.css("left", left); 
  181.  
  182. $(target).mousemove(function (e) { 
  183. var top = e.clientY + $(window).scrollTop() - divtips.height() - 18; 
  184. var left = e.clientX; 
  185. divtips.css("top", top); 
  186. divtips.css("left", left); 
  187. }); 
  188. }, 
  189.  
  190. //移除提示 
  191. removetips: function () { 
  192. $(".div-tips").remove(); 
  193. }; 
  194.  
  195. $(function () { 
  196. SimpoValidate.init(); 
  197. }); 

如何使用:

Edit頁面:

 

 
  1. @using Model.Suya; 
  2. @{ 
  3. ViewBag.Title = "Add"
  4. Layout = "~/Views/Shared/_Layout.cshtml"
  5. @{ 
  6. List<sys_post> postList = (List<sys_post>)ViewData["postList"]; 
  7. sys_post post = (sys_post)ViewData["post"]; 
  8. <script type="text/javascript"
  9. $(function () { 
  10. //部門樹 
  11. $('#dept').combotree({ 
  12. url: 'GetDeptTree'
  13. required: false
  14. checkbox: true
  15. onLoadSuccess: function () { 
  16. $('#dept').combotree('setValue'"@(post.depCode)"); 
  17. }); 
  18.  
  19. //操作結果 
  20. $("#ifrm").load(function (data) { 
  21. var data = eval("(" + $("#ifrm").contents().find("body").html() + ")"); 
  22. alert(data.msg); 
  23. if (data.ok) back(); 
  24. }); 
  25.  
  26. $("select[name='postLevel']").find("option[value='@(post.postLevel)']").attr("selected""selected"); 
  27. }); 
  28.  
  29. //保存 
  30. function save() { 
  31. if (valid()) { 
  32. $("#frm").submit(); 
  33.  
  34. //驗證 
  35. function valid() { 
  36. var dept = $("input[name='dept']"); 
  37. if (!dept.val()) { 
  38. SimpoValidate.hilight(dept.parent(), "請選擇所屬部門"); 
  39. else { 
  40. SimpoValidate.removehilight(dept.parent()); 
  41.  
  42. return SimpoValidate.valid(); 
  43.  
  44. //返回 
  45. function back() { 
  46. parent.$('#ttTab').tabs('select'"崗位管理"); 
  47. var tab = parent.$('#ttTab').tabs('getSelected'); 
  48. tab.find("iframe").contents().find("#btnSearch").click(); 
  49. parent.$("#ttTab").tabs('close''修改崗位信息'); 
  50. </script> 
  51. <div class="tiao"
  52. <input type="button" class="submit_btn" value="保存" onclick="save()" /> 
  53. <input type="button" class="submit_btn" value="返回" onclick="back()" /> 
  54. </div> 
  55. <iframe id="ifrm" name="ifrm" style="display: none;"></iframe> 
  56. <form id="frm" method="post" enctype="multipart/form-data" action="/HR/PostManage/SaveEdit?id=@(post.id)" 
  57. target="ifrm"
  58. <div class="adminMainContent"
  59. <div class="box"
  60. <div class="box-title"
  61. 基礎信息 
  62. </div> 
  63. <div class="box-content"
  64. <table cellpadding="0" cellspacing="0" class="detail" width="100%"
  65. <tr> 
  66. <td class="title"
  67. <span class="mst">*</span>崗位名稱: 
  68. </td> 
  69. <td style="width: 35%;"
  70. <input type="text" class="xinxi_txt" name="postName" value="@post.postName" /> 
  71. <span class="valid" msg="必填,且長度不能超過50" rule="^(.|/n){0,50}$"></span> 
  72. </td> 
  73. <td class="title"
  74. <span class="mst">*</span>崗位編號: 
  75. </td> 
  76. <td style="width: 35%;"
  77. <input type="text" class="xinxi_txt" name="postCode" value="@post.postCode" /> 
  78. <span class="valid" msg="必填,且長度不能超過20" rule="^(.|/n){0,20}$" ajaxaction="/HR/PostManage/AjaxCheckPostCode?id=@post.id"
  79. </span> 
  80. </td> 
  81. </tr> 
  82. <tr> 
  83. <td class="title"
  84. <span class="mst">*</span> 所屬部門: 
  85. </td> 
  86. <td style="width: 35%;"
  87. <input type="text" name="depCode" id="dept" class="easyui-combotree" style="height: 30px;" /> 
  88. </td> 
  89. <td class="title"
  90. <span class="mst">*</span>匯報對象: 
  91. </td> 
  92. <td style="width: 35%;"
  93. <select class="xueli" name="reportPostCode" id="agreementType"
  94. <option value="" selected="selected">==請選擇==</option> 
  95. @foreach (sys_post item in postList) 
  96. if (item.postCode == post.reportPostCode) 
  97. <option value="@item.postCode" selected="selected">@item.postName</option> 
  98. else 
  99. <option value="@item.postCode">@item.postName</option> 
  100. </select> 
  101. <span class="valid" msg="請選擇合同分類"
  102. </td> 
  103. </tr> 
  104. <tr> 
  105. <td class="title"
  106. <span class="mst">*</span>崗位級別: 
  107. </td> 
  108. <td style="width: 35%;"
  109. <select class="xueli" name="postLevel"
  110. <option value="" selected="selected">==請選擇==</option> 
  111. <option value="1">1</option> 
  112. <option value="2">2</option> 
  113. <option value="3">3</option> 
  114. <option value="4">4</option> 
  115. <option value="5">5</option> 
  116. <option value="6">6</option> 
  117. </select> 
  118. <span class="valid" msg="請選擇崗位級別"
  119. </td> 
  120. <td class="title"
  121. </td> 
  122. <td style="width: 35%;"
  123. </td> 
  124. </tr> 
  125. <tr> 
  126. <td class="title"
  127. <span class="mst">*</span>備注: 
  128. </td> 
  129. <td colspan="3" style="width: 35%;"
  130. <textarea name="remarks" style="width: 500px;">@post.remarks</textarea> 
  131. <span class="valid" msg="長度不得超過500" rule="^(.|/n){0,500}$"></span> 
  132. </td> 
  133. </tr> 
  134. </table> 
  135. </div> 
  136. </div> 
  137. </div> 
  138. </form> 

效果圖:

自己編寫的支持Ajax驗證的JS表單驗證插件

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美电影在线观看高清| 亚洲第一区第一页| 性亚洲最疯狂xxxx高清| 欧美电影免费观看电视剧大全| 久久99精品久久久久久噜噜| 国语自产精品视频在线看| 久久在线视频在线| 欧美区在线播放| 久久久久国色av免费观看性色| 亚洲精品动漫久久久久| 最近免费中文字幕视频2019| 一本一本久久a久久精品综合小说| 91久久精品国产91久久性色| 国产亚洲福利一区| 亚洲欧美在线一区| 亚洲高清久久网| 欧美xxxx18国产| 欧美情侣性视频| 亚洲一区二区中文字幕| 国产成人精品亚洲精品| 中文字幕精品在线视频| 亚洲成色www8888| 国产精品美女久久久免费| 久久精品视频亚洲| 美女av一区二区| 高清欧美性猛交xxxx黑人猛交| 亚洲精品二三区| 日韩精品日韩在线观看| 国产精品高潮视频| 亚洲精品国产免费| 日韩免费av在线| 日韩精品在线观看一区| 亚洲激情视频在线播放| 亚洲欧美日韩一区在线| 国产精品亚洲第一区| 精品色蜜蜜精品视频在线观看| 国产一区二区三区三区在线观看| 亚洲人成电影在线观看天堂色| 日韩免费视频在线观看| 欧美性生交xxxxx久久久| 日韩视频中文字幕| 亚洲国产成人精品久久| 在线色欧美三级视频| 亚洲欧洲中文天堂| 久久亚洲私人国产精品va| 国产精品户外野外| 精品国产自在精品国产浪潮| 日韩在线免费av| 欧美日韩午夜视频在线观看| 亚洲精品成人免费| 国产69精品久久久久9999| 91精品国产乱码久久久久久蜜臀| 欧美午夜激情在线| 久久伊人精品视频| 日韩精品在线免费| 国产婷婷97碰碰久久人人蜜臀| 亚洲国产成人精品久久久国产成人一区| 91av在线不卡| 国产精品高精视频免费| 国产综合色香蕉精品| 亚洲男人天堂久| 亚洲成人精品av| 亚洲欧美国产va在线影院| 青青草原一区二区| 国产精品青青在线观看爽香蕉| 成人女保姆的销魂服务| 国产精品久在线观看| 在线观看亚洲视频| 欧美日韩精品在线视频| 欧美日韩在线一区| 欧美精品在线播放| 一本色道久久88亚洲综合88| 日韩电影中文字幕在线观看| 久久国产精品久久久久| 日韩中文字幕在线播放| 久久中文字幕在线视频| 久久福利网址导航| 性欧美亚洲xxxx乳在线观看| 国产美女久久精品| 日韩av中文字幕在线免费观看| 琪琪亚洲精品午夜在线| 91色琪琪电影亚洲精品久久| 国产精品久久久久久久久久久久久久| 亚洲国产精品小视频| 亚洲精品美女网站| 2019亚洲男人天堂| 国产69精品久久久久99| 欧美日韩在线视频观看| 97色在线播放视频| 久久久在线视频| 欧美亚洲另类制服自拍| 插插插亚洲综合网| 亚洲精品福利资源站| 综合网中文字幕| 久久久视频在线| 亚洲毛茸茸少妇高潮呻吟| 日韩免费在线免费观看| 久久久国产视频91| 国产亚洲美女精品久久久| 亚洲国产精品久久久久秋霞不卡| 国产在线拍揄自揄视频不卡99| 欧美大学生性色视频| 国产精品国产三级国产aⅴ浪潮| 日av在线播放中文不卡| 日韩一区二区三区xxxx| 国产精品国产三级国产aⅴ9色| 亚洲激情自拍图| 国产99久久精品一区二区 夜夜躁日日躁| 91国内揄拍国内精品对白| 黑人精品xxx一区| 91久久在线播放| 久久99精品视频一区97| 午夜精品三级视频福利| 精品国产一区二区三区久久狼5月| 亚洲第一精品夜夜躁人人躁| 亚洲自拍在线观看| 尤物九九久久国产精品的分类| 精品亚洲va在线va天堂资源站| 国产精品白嫩初高中害羞小美女| 日日骚久久av| 色婷婷**av毛片一区| 亚洲色无码播放| 亚洲精品狠狠操| 久久手机精品视频| 欧美一区三区三区高中清蜜桃| 国产精品中文在线| 欧美一区二区三区艳史| 国产成人精品午夜| 欧美xxxx做受欧美| 日韩av黄色在线观看| 国产精品视频大全| 国产成人精彩在线视频九色| 91国内揄拍国内精品对白| 欧美精品在线免费观看| 国产精品极品美女在线观看免费| 国产精品成久久久久三级| 欧美成人激情在线| 久久久久久噜噜噜久久久精品| 欧美一区二区大胆人体摄影专业网站| 97久久精品国产| 亚洲一区二区三区四区视频| 欧美成人一区在线| 性金发美女69hd大尺寸| 亚洲美女又黄又爽在线观看| 17婷婷久久www| 91视频国产高清| 亚洲日本中文字幕免费在线不卡| 最近中文字幕日韩精品| 久久久99免费视频| 国产精品综合网站| 国产精品久久久久久久久久三级| 日韩视频亚洲视频| 亚洲天堂免费视频| 精品五月天久久| 国产精品日韩电影| 亚洲va欧美va在线观看| 亚洲久久久久久久久久久| 国产精品网红直播| 欧美一区二区三区图| 日韩免费在线视频| 97久久精品人人澡人人爽缅北| 国产91ⅴ在线精品免费观看| 国产欧美日韩中文字幕在线| 亚洲免费视频网站|