加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 创业 > C语言 > 正文

策略模式-校验表单

发布时间:2020-12-15 00:28:24 所属栏目:C语言 来源:网络整理
导读:table class="html5" tr class="li1" td class="ln"pre class="de1"1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
<tr class="li1">
<td class="ln"><pre class="de1">1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107

? ? 策略模式-校验表单> ? ? > > ? ? > ? ? ? ? 用户名: > ? ? ? ? 密码: > ? ? ? ? 手机号码: > ? ? ? ? >提交> ? ? > ? ? > ? ? ? ? // 策略对象 ? ? ? ? var strategies = { ? ? ? ? ? ? isNoEmpty: function (value,errorMsg) { ? ? ? ? ? ? ? ? if (value === '') { ? ? ? ? ? ? ? ? ? ? return errorMsg; ? ? ? ? ? ? ? ? } ? ? ? ? ? ? },? ? ? ? ? ? isNoSpace: function (value,errorMsg) { ? ? ? ? ? ? ? ? if (value.trim() === '') { ? ? ? ? ? ? ? ? ? ? return errorMsg; ? ? ? ? ? ? ? ? } ? ? ? ? ? ? },? ? ? ? ? ? minLength: function (value,length,errorMsg) { ? ? ? ? ? ? ? ? if (value.trim().length , : function ,errorMsg .length > length) { ? ? ? ? ? ? ? ? ? ? return errorMsg; ? ? ? ? ? ? ? ? } ? ? ? ? ? ? },? ? ? ? ? ? isMobile: function (value,errorMsg) { ? ? ? ? ? ? ? ? if (!/^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|17[7]|18[0|1|2|3|5|6|7|8|9])d{8}$/.test(value)) { ? ? ? ? ? ? ? ? ? ? return errorMsg; ? ? ? ? ? ? ? ? } ? ? ? ? ? ? ? ? ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? ? // 验证类 ? ? ? ? var Validator = function() { ? ? ? ? ? ? this.cache = []; ? ? ? ? } ? ? ? ? Validator.prototype.add = function(dom,rules) { ? ? ? ? ? ? var self = this; ? ? ? ? ? ? for(var i = 0,rule; rule = rules[i++];) { ? ? ? ? ? ? ? ? (function(rule) { ? ? ? ? ? ? ? ? ? ?var strategyAry = rule.strategy.split(':'); ? ? ? ? ? ? ? ? ? ?var errorMsg = rule.errorMsg; ? ? ? ? ? ? ? ? ? ?self.cache.push(function() { ? ? ? ? ? ? ? ? ? ? var strategy = strategyAry.shift(); ? ? ? ? ? ? ? ? ? ? strategyAry.unshift(dom.value); ? ? ? ? ? ? ? ? ? ? strategyAry.push(errorMsg); ? ? ? ? ? ? ? ? ? ? return strategies[strategy].apply(dom,strategyAry); ? ? ? ? ? ? ? ? ? ?}) ? ? ? ? ? ? ? ? })(rule) ? ? ? ? ? ? } ? ? ? ? }; ? ? ? ? Validator.prototype.start = function() { ? ? ? ? ? ? for(var i = 0,validatorFunc; validatorFunc = this.cache[i++];) { ? ? ? ? ? ? ? ? var errorMsg = validatorFunc(); ? ? ? ? ? ? ? ? if (errorMsg) { ? ? ? ? ? ? ? ? ? ? return errorMsg; ? ? ? ? ? ? ? ? } ? ? ? ? ? ? } ? ? ? ? }; ? ? ? ? ? // 调用代码 ? ? ? ? var registerForm = document.getElementById('registerForm'); ? ? ? ? ? var validataFunc = function() { ? ? ? ? ? ? var validator = new Validator(); ? ? ? ? ? ? validator.add(registerForm.userName,[{ ? ? ? ? ? ? ? ? strategy: 'isNoEmpty',? ? ? ? ? ? ? ? errorMsg: '用户名不可为空' ? ? ? ? ? ? },{ ? ? ? ? ? ? ? ? strategy: 'isNoSpace',? ? ? ? ? ? ? ? errorMsg: '不允许以空白字符命名' ? ? ? ? ? ? },{ ? ? ? ? ? ? ? ? strategy: 'minLength:2',? ? ? ? ? ? ? ? errorMsg: '用户名长度不能小于2位' ? ? ? ? ? ? }]); ? ? ? ? ? ? validator.add(registerForm.password,[ { ? ? ? ? ? ? ? ? strategy: 'minLength:6',? ? ? ? ? ? ? ? errorMsg: '密码长度不能小于6位' ? ? ? ? ? ? }]); ? ? ? ? ? ? validator.add(registerForm.phoneNumber,[{ ? ? ? ? ? ? ? ? strategy: 'isMobile',? ? ? ? ? ? ? ? errorMsg: '请输入正确的手机号码格式' ? ? ? ? ? ? }]); ? ? ? ? ? ? var errorMsg = validator.start(); ? ? ? ? ? ? return errorMsg; ? ? ? ? } ? ? ? ? ? registerForm.onsubmit = function() { ? ? ? ? ? ? var errorMsg = validataFunc(); ? ? ? ? ? ? if (errorMsg) { ? ? ? ? ? ? ? ? alert(errorMsg); ? ? ? ? ? ? ? ? return false; ? ? ? ? ? ? } ? ? ? ? } ? ? > > >(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

<table class="html5">

    推荐文章
      热点阅读