jQuery獲取radio選中項(xiàng)的值實(shí)例
639
2024-02-27
easyui 的validatebox()提供了自定義驗(yàn)證的方法,為此我把一些常用的數(shù)據(jù)驗(yàn)證匯總了一下,代碼如下
$.extend($.fn.validatebox.defaults.rules, { CHS: { validator: function (value, param) { return /^[u0391-uFFE5]+$/.test(value); }, message: '請(qǐng)輸入漢字' }, ZIP: { validator: function (value, param) { return /^[1-9]d{5}$/.test(value); }, message: '郵政編碼不存在' }, QQ: { validator: function (value, param) { return /^[1-9]d{4,10}$/.test(value); }, message: 'QQ號(hào)碼不正確' }, mobile: { validator: function (value, param) { return /^(((d{2,3}))|(d{3}-))?13d{9}$/.test(value); }, message: '手機(jī)號(hào)碼不正確' }, loginName: { validator: function (value, param) { return /^[u0391-uFFE5w]+$/.test(value); }, message: '登錄名稱只允許漢字、英文字母、數(shù)字及下劃線。' }, safepass: { validator: function (value, param) { return safePassword(value); }, message: '密碼由字母和數(shù)字組成,至少6位' }, equalTo: { validator: function (value, param) { return value == $(param[0]).val(); }, message: '兩次輸入的字符不一至' }, number: { validator: function (value, param) { return /^d+$/.test(value); }, message: '請(qǐng)輸入數(shù)字' }, idcard: { validator: function (value, param) { return idCard(value); }, message:'請(qǐng)輸入正確的身份證號(hào)碼' } }); /* 密碼由字母和數(shù)字組成,至少6位 */ var safePassword = function (value) { return !(/^(([A-Z]*|[a-z]*|d*|[-_~!@#$%^&*.()[]{}<>?\/'"]*)|.{0,5})$|s/.test(value)); } var idCard = function (value) { if (value.length == 18 && 18 != value.length) return false; var number = value.toLowerCase(); var d, sum = 0, v = '10x98765432', w = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2], a = '11,12,13,14,15,21,22,23,31,32,33,34,35,36,37,41,42,43,44,45,46,50,51,52,53,54,61,62,63,64,65,71,81,82,91'; var re = number.match(/^(d{2})d{4}(((d{2})(d{2})(d{2})(d{3}))|((d{4})(d{2})(d{2})(d{3}[xd])))$/); if (re == null || a.indexOf(re[1]) < 0) return false; if (re[2].length == 9) { number = number.substr(0, 6) + '19' + number.substr(6); d = ['19' + re[4], re[5], re[6]].join('-'); } else d = [re[9], re[10], re[11]].join('-'); if (!isDateTime.call(d, 'yyyy-MM-dd')) return false; for (var i = 0; i < 17; i++) sum += number.charAt(i) * w[i]; return (re[2].length == 9 || number.charAt(17) == v.charAt(sum % 11)); } var isDateTime = function (format, reObj) { format = format || 'yyyy-MM-dd'; var input = this, o = {}, d = new Date(); var f1 = format.split(/[^a-z]+/gi), f2 = input.split(/D+/g), f3 = format.split(/[a-z]+/gi), f4 = input.split(/d+/g); var len = f1.length, len1 = f3.length; if (len != f2.length || len1 != f4.length) return false; for (var i = 0; i < len1; i++) if (f3[i] != f4[i]) return false; for (var i = 0; i < len; i++) o[f1[i]] = f2[i]; o.yyyy = s(o.yyyy, o.yy, d.getFullYear(), 9999, 4); o.MM = s(o.MM, o.M, d.getMonth() + 1, 12); o.dd = s(o.dd, o.d, d.getDate(), 31); o.hh = s(o.hh, o.h, d.getHours(), 24); o.mm = s(o.mm, o.m, d.getMinutes()); o.ss = s(o.ss, o.s, d.getSeconds()); o.ms = s(o.ms, o.ms, d.getMilliseconds(), 999, 3); if (o.yyyy + o.MM + o.dd + o.hh + o.mm + o.ss + o.ms < 0) return false; if (o.yyyy < 100) o.yyyy += (o.yyyy > 30 ? 1900 : 2000); d = new Date(o.yyyy, o.MM - 1, o.dd, o.hh, o.mm, o.ss, o.ms); var reVal = d.getFullYear() == o.yyyy && d.getMonth() + 1 == o.MM && d.getDate() == o.dd && d.getHours() == o.hh && d.getMinutes() == o.mm && d.getSeconds() == o.ss && d.getMilliseconds() == o.ms; return reVal && reObj ? d : reVal; function s(s1, s2, s3, s4, s5) { s4 = s4 || 60, s5 = s5 || 2; var reVal = s3; if (s1 != undefined && s1 != '' || !isNaN(s1)) reVal = s1 * 1; if (s2 != undefined && s2 != '' && !isNaN(s2)) reVal = s2 * 1; return (reVal == s1 && s1.length != s5 || reVal > s4) ? -10000 : reVal; } };
頁(yè)面中要引入jquery.js 和 easyui.min.js
html 代碼中使用如下
<table class="grid" id="uiform"> <tr><td>登錄名:</td><td><input required="true" id="txtUsername" type="text" class="txt03" /></td><td>真實(shí)姓名:</td><td><input id="txtTruename" validType="CHS" required="true" type="text" class="txt03" /></td></tr> <tr><td>登錄密碼:</td><td><input validType="safepass" required="true" id="txtPassword" name="password" type="password" class="txt03" /></td><td>Email:</td><td><input id="txtEmail" name="email" validType="email" type="text" class="txt03" /></td></tr> <tr><td>身份證號(hào):</td><td><input validType="idcard" id="txtIdcard" name="idcard" type="text" class="txt03" /></td><td>QQ:</td><td><input validType="QQ" id="txtQq" name="qq" type="text" class="txt03" /></td></tr> <tr><td>手機(jī):</td><td><input validType="mobile" id="txtMobile" name="mobile" type="text" class="txt03" /></td><td>電話:</td><td><input id="txtTel" name="tel" type="text" class="txt03" /></td></tr> <tr><td>家庭住址:</td><td colspan="3"><input validType="equalTo[txtMobile]" style="width:80%" id="txtHomeaddr" name="homeaddr" type="text" class="txt03" /></td></tr> <tr><td>備注:</td><td colspan="3"> <input type="text" style="width:80%" class="txt03" id="txtRemark"></textarea></td></tr> <tr><td> </td><td colspan="3"><input id="Checkbox1" type="checkbox" /><label>超級(jí)管理員</label> <input id="Checkbox2" type="checkbox" /><label>禁用</label></td></tr> </table>
這一段JS 是必不可少的
$(function(){ $('#uiform input').each(function () { if ($(this).attr('required') || $(this).attr('validType')) $(this).validatebox(); }) });
這樣就ok了
如果在提交時(shí)驗(yàn)證表單有沒(méi)有通過(guò)驗(yàn)證,則可使用下面的代碼
var flag = true; $('#uiform input').each(function () { if ($(this).attr('required') || $(this).attr('validType')) { if (!$(this).validatebox('isValid')) { flag = false; return; } } }) if (flag) alert('驗(yàn)證通過(guò)!'); else alert('驗(yàn)證失敗!');
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持綠夏網(wǎng)。
#免責(zé)聲明#
本站[綠夏技術(shù)導(dǎo)航]提供的一切軟件、教程和內(nèi)容信息僅限用于學(xué)習(xí)和研究目的;不得將上述內(nèi)容用于商業(yè)或者非法用途,否則,一切后果請(qǐng)用戶自負(fù)。本站信息來(lái)自網(wǎng)絡(luò)收集整理,版權(quán)爭(zhēng)議與本站無(wú)關(guān)。您必須在下載后的24個(gè)小時(shí)之內(nèi),從您的電腦或手機(jī)中徹底刪除上述內(nèi)容。如果您喜歡該程序或內(nèi)容,請(qǐng)支持正版,購(gòu)買注冊(cè),得到更好的正版服務(wù)。我們非常重視版權(quán)問(wèn)題,如有侵權(quán)請(qǐng)郵件[admin@lxwl520.com]與我們聯(lián)系進(jìn)行刪除處理。敬請(qǐng)諒解!