国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > AJAX > 正文

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

2024-09-01 08:33:30
字體:
供稿:網(wǎng)友

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

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

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

驗證時機:1、點擊提交按鈕時顯式調(diào)用驗證方法;2、當(dāng)元素觸發(fā)blur時驗證。

插件代碼:

CSS:

 

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

JS:

 

 
  1. /** 
  2. * suxiang 
  3. * 2014年12月22日 
  4. * 驗證插件 
  5. */ 
  6.  
  7. SimpoValidate = { 
  8. //驗證規(guī)則 
  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. //獲取驗證規(guī)則 
  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. //操作結(jié)果 
  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. 基礎(chǔ)信息 
  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表單驗證插件

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 黑水县| 白城市| 龙胜| 商城县| 蕲春县| 嫩江县| 红河县| 政和县| 永仁县| 商丘市| 十堰市| 金湖县| 高尔夫| 肥乡县| 门头沟区| 西畴县| 宿州市| 崇信县| 曲阳县| 清流县| 九龙城区| 西华县| 繁昌县| 施秉县| 奉化市| 泌阳县| 武城县| 濮阳市| 乐清市| 额尔古纳市| 尚义县| 白朗县| 弋阳县| 丰城市| 将乐县| 玉溪市| 朝阳区| 丰原市| 大城县| 航空| 上林县|