JavaScript設計モードのポリシーモードを学ぶ
3713 ワード
不変の部分と変化する部分を区切るのが各デザインモードのテーマです.本の大通りはローマに通じている.圧縮ファイルなど、zipアルゴリズムを使用したり、gzipアルゴリズムを使用したりすることができます.柔軟で多様で、戦略モデルを採用して解決することができます.
一、定義
一連のアルゴリズムを定義し、それらを一つ一つカプセル化し、互いに置き換えることができます.ポリシークラスモードに基づくプログラムは、少なくとも2つの部分から構成される.最初の部分は、特定のアルゴリズムをカプセル化し、特定の計算プロセスを担当するポリシークラスのセットです.第2の部分は環境クラスContextであり、Contextは顧客の要求を受信し、その後、あるポリシークラスに要求を委任する.
二、例
ボーナスを計算する.パフォーマンスはSの4倍、パフォーマンスはAの3倍、パフォーマンスはBの2倍の給与です.
三、延長:フォーム検証
この文書ではjavascriptプログラムの設計を学ぶのに役立つことを願っています.
一、定義
一連のアルゴリズムを定義し、それらを一つ一つカプセル化し、互いに置き換えることができます.ポリシークラスモードに基づくプログラムは、少なくとも2つの部分から構成される.最初の部分は、特定のアルゴリズムをカプセル化し、特定の計算プロセスを担当するポリシークラスのセットです.第2の部分は環境クラスContextであり、Contextは顧客の要求を受信し、その後、あるポリシークラスに要求を委任する.
二、例
ボーナスを計算する.パフォーマンスはSの4倍、パフォーマンスはAの3倍、パフォーマンスはBの2倍の給与です.
var strategies = {
"S": function(salary) {
return salary * 4;
},
"A": function(salary) {
return salary * 3;
},
"B": function(salary) {
return salary * 2;
}
};
//
var calculateBonus = function(level, salary) {
return strategies[level](salary);
};
//
console.log(calculateBonus("S", 20000));
console.log(calculateBonus("A", 20000));
console.log(calculateBonus("B", 20000));
三、延長:フォーム検証
/* */
var validateStrategies = {
isEmpty: function (val, errorMsg) {
if (!val) {
return errorMsg;
}
},
isURL: function (val, errorMsg) {
if (!new RegExp("^(http:\\/\\/|https:\\/\\/)?([\\w\\-]+\\.)+[\\w\\-]+(\\/[\\w\\-\\.\\/?\\@\\%\\!\\&=\\+\\~\\:\\#\\;\\,]*)?$").test(val)) {
return errorMsg;
}
},
isEmail: function (val, errorMsg) {
if (!new RegExp('\\w+((-\\w+)|(\\.\\w+))*\\@[A-Za-z0-9]+((\\.|-)[A-Za-z0-9]+)*\\.[A-Za-z0-9]+').test(val)) {
return errorMsg;
}
},
isMaxLength: function (val, length, errorMsg) {
if (val.length > length) {
return errorMsg;
}
},
isMinLength: function (val, length, errorMsg) {
if (val.length < length) {
return errorMsg;
}
}
};
/* validator */
var validator = function () {
//
this.cache = [];
};
/**
*
* @param dom dom
* @param rules
*/
validator.prototype.add = function (dom, rules) {
var self = this;
for (var i = 0, rule; rule = rules[i++];) {
(function (rule) {
var strategyAry = rule.strategy.split(":"); // ["isMaxLength", "10"]
var errorMsg = rule.errorMsg; // " 10"
self.cache.push(function () {
var strategy = strategyAry.shift(); // "isMaxLength"
strategyAry.unshift(dom.value); // ["1@qq", "10"]
strategyAry.push(errorMsg); // ["1@qq", "10", " 10"]
return validateStrategies[strategy].apply(dom, strategyAry);
});
})(rule);
}
};
/* */
validator.prototype.start = function () {
for (var i = 0, validateFunc; validateFunc = this.cache[i++];) {
var errorMsg = validateFunc();
if (errorMsg) {
return errorMsg;
}
}
};
//
var validatorInstance = new validator();
validatorInstance.add(
document.getElementsByName("email")[0],
[{
strategy: "isEmpty",
errorMsg: " "
},{
strategy: "isMaxLength:10",
errorMsg: " 10"
},{
strategy: "isEmail",
errorMsg: "email "
}]);
errorMsg = validatorInstance.start();
この文書ではjavascriptプログラムの設計を学ぶのに役立つことを願っています.