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

首頁 > 開發 > AJAX > 正文

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

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

創建一個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
亚洲高清av在线| 久久久精品在线观看| 国产精品国语对白| 青青草精品毛片| 国产精品狠色婷| 欧美高清无遮挡| 中文字幕欧美日韩va免费视频| 亚洲精品97久久| 91豆花精品一区| 国产xxx69麻豆国语对白| 国产精品一区专区欧美日韩| 久国内精品在线| 欧美中文在线观看| 国产亚洲欧美aaaa| 国产欧美在线视频| 成人黄色在线观看| 高清日韩电视剧大全免费播放在线观看| 91久久久亚洲精品| 久久久国产在线视频| 在线免费观看羞羞视频一区二区| 亚洲伊人久久大香线蕉av| 久久av资源网站| 亚洲精品美女在线| 欧美激情伊人电影| 成人av.网址在线网站| 欧美在线xxx| 欧美一级电影久久| 国产精品久久二区| 亚洲毛片在线免费观看| 欧美片一区二区三区| 欧美综合第一页| 国产精品久久久| 国产精品男人爽免费视频1| 国产主播在线一区| 日韩在线观看免费全| 久久九九精品99国产精品| 亚洲人成在线观看网站高清| 日韩一区二区av| 久久最新资源网| 国产精品视频一区二区高潮| 国产精品日韩在线观看| 在线电影欧美日韩一区二区私密| 97在线免费观看视频| 久久免费视频网站| 国产情人节一区| 久久综合免费视频| 欧美日韩美女视频| 亚洲视频综合网| 成年无码av片在线| 国产在线精品播放| 66m—66摸成人免费视频| 日本一欧美一欧美一亚洲视频| 蜜臀久久99精品久久久久久宅男| 国产精品美女免费看| 国产精品色视频| www国产91| 国产精品丝袜久久久久久不卡| 欧美大肥婆大肥bbbbb| 欧美午夜精品在线| 欧美一级大片视频| 清纯唯美亚洲综合| 日韩av有码在线| 日韩精品高清在线| 日本一欧美一欧美一亚洲视频| 国产91在线播放九色快色| 色综合91久久精品中文字幕| 亚洲精品福利在线| 国产91九色视频| 国产日韩在线观看av| 性欧美亚洲xxxx乳在线观看| 欧美精品免费在线| 欧美成人免费网| 伊人av综合网| 91国自产精品中文字幕亚洲| 91精品在线看| 国产精品高潮呻吟视频| 日韩精品视频在线免费观看| 欧美www在线| 国产精品日日摸夜夜添夜夜av| 欧美精品激情blacked18| 亚洲欧洲日韩国产| 成人激情视频小说免费下载| 国产精品久久久久久久久男| 国产精品久久久久久久7电影| 亚洲精品99久久久久中文字幕| 亚洲欧洲在线看| 亚洲无限乱码一二三四麻| 国产精品视频中文字幕91| 欧美午夜丰满在线18影院| 欧美黄色性视频| 国产日本欧美视频| 久久精品国产亚洲7777| 日韩成人在线网站| 亚洲精品电影久久久| 91精品国产综合久久久久久蜜臀| 97成人精品区在线播放| 麻豆乱码国产一区二区三区| 国产精品a久久久久久| 国产精品香蕉av| 欧美性做爰毛片| 欧美高清在线播放| 国产午夜精品视频免费不卡69堂| 国产午夜精品视频| 国产精品视频网站| 国产成人精品最新| 国产欧美精品日韩精品| 欧美性生活大片免费观看网址| 日韩欧美亚洲综合| 欧美一区二区三区图| 欧美高清一级大片| 亚洲有声小说3d| 国产v综合v亚洲欧美久久| 一区二区三区在线播放欧美| 欧美肥臀大乳一区二区免费视频| 综合久久五月天| 国产精品 欧美在线| 精品日本美女福利在线观看| 国产成人精品电影久久久| 亚洲激情在线观看视频免费| 国产欧美精品在线播放| 欧美国产日产韩国视频| 亚洲精品ady| 欧美专区国产专区| 91精品国产91久久久久福利| 26uuu亚洲伊人春色| 国产视频精品xxxx| 亚洲18私人小影院| 日韩在线观看免费av| 高清视频欧美一级| 日韩美女视频在线观看| 国产91精品在线播放| 91性高湖久久久久久久久_久久99| 国产精品一区二区三| 亚州精品天堂中文字幕| 91精品国产99| 国产91九色视频| 亚洲日韩中文字幕| 4p变态网欧美系列| 国产成人自拍视频在线观看| 久久久精品日本| 上原亚衣av一区二区三区| 精品电影在线观看| 97精品国产97久久久久久| 亚洲色图激情小说| 欧美小视频在线| 亚洲视频在线免费看| 欧美日韩亚洲视频一区| 亚洲一区二区中文字幕| 欧洲亚洲女同hd| 午夜精品福利视频| 国产精品第七十二页| 韩国欧美亚洲国产| 国产精品18久久久久久麻辣| 成人免费高清完整版在线观看| 亚洲精品中文字幕女同| 日韩免费av一区二区| 国产精品福利网站| 精品动漫一区二区三区| 亚洲午夜精品久久久久久久久久久久| 日韩电影在线观看免费| 精品亚洲精品福利线在观看| 色先锋久久影院av| 欧美性猛交xxx| 久久精品视频网站|