文章目錄
  1. 1. 定义
  2. 2. 一个使用策略模式文本输入框校验规则样例代码

定义

定义一系列的算法,把他们一个个封装起来,并且使它们可以互相替换
当然策略模式并不仅仅可以封装算法,也可以封装一系列的’业务规则’或者说是’应用逻辑’,只要这些业务规则指向的目标一致,并且可以被替换使用,我们就可以用策略模式来封装它们
策略模式主要是实现了松散耦合

一个使用策略模式文本输入框校验规则样例代码

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
<body>
<!-- 一个使用策略模式文本输入框校验规则样例代码 -->
<form action="javascript:;" id="registerForm" method="post">
请输入用户名: <input type="text" name="userName">
请输入密码: <input type="password" name="password">
请输入手机号码: <input type="phoneName" name="phoneName">
<button>提交</button>

</form>

<script>
// 定义策略
var strategies = {
//判断是否为空
isNonEmpty: function(value, errorMsg){
if(value === ""){
return errorMsg;
}
},
//判断最小长度
minLength: function(value, length, errorMsg){
if (value.length < length) {
return errorMsg;
}
},
//判断手机号是否合法
isMoblile: function(value, errorMsg){
if(!/(^1[3|5|8][0-9]{9}$)/.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(){
//删除参数数组的要校验的规则并用strategy接收
var strategy = strategyAry.shift();
//接收dom的value值作为第一个参数
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:'isNonEmpty',
errorMsg:'用户名不能为空'
},
{
strategy: 'minLength:6',
errorMsg: '用户名长度不能小于6位'
}]);
validator.add(registerForm.password,[
{
strategy:'minLength:6',
errorMsg:'密码长度不能小于6位'
}]);
validator.add(registerForm.phoneName,[
{
strategy:'isMoblile',
errorMsg:'手机号码格式不正确'
}]);
//启动校验程序
var errorMsg = validator.start();
return errorMsg;
};
//绑定事件
registerForm.onsubmit = function(){
var errorMsg = validataFunc();
console.log('test');
if(errorMsg){
alert(errorMsg);
return false;
}
return false;
};

</script>
</body>
文章目錄
  1. 1. 定义
  2. 2. 一个使用策略模式文本输入框校验规则样例代码