代码拉取完成,页面将自动刷新
<!--
* @Author: your name
* @Date: 2022-03-30 15:50:43
* @LastEditTime: 2022-03-30 16:19:09
* @LastEditors: Please set LastEditors
* @Description: 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
* @FilePath: \geyao\geyao\职责链模式220330.html
-->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>职责链模式</title>
</head>
<body>
<script>
function order500(orderType, isPay, count) {
if (orderType == 1 && isPay == true) {
console.log("亲爱的用户,您中奖了100元红包了");
} else {
//我不知道下一个节点是谁,反正把请求往后面传递
return "nextSuccessor";
}
};
function order200(orderType, isPay, count) {
if (orderType == 2 && isPay == true) {
console.log("亲爱的用户,您中奖了20元红包了");
} else {
//我不知道下一个节点是谁,反正把请求往后面传递
return "nextSuccessor";
}
};
function orderNormal(orderType, isPay, count) {
// 普通用户来处理中奖信息
if (count > 0) {
console.log("亲爱的用户,您已抽到10元优惠卷");
} else {
console.log("亲爱的用户,请再接再厉哦");
}
}
// 下面需要编写职责链模式的封装构造函数方法
var Chain = function (fn) {
console.log(fn,"fn")
console.log(this,"this")
this.fn = fn;
this.successor = null;
};
Chain.prototype.setNextSuccessor = function (successor) {
return this.successor = successor;
}
// 把请求往下传递
Chain.prototype.passRequest = function () {
console.log(this,"passRequest")
var ret = this.fn.apply(this, arguments);
if (ret === 'nextSuccessor') {
return this.successor && this.successor.passRequest.apply(this.successor, arguments);
}
return ret;
}
//现在我们把3个函数分别包装成职责链节点:
var chainOrder500 = new Chain(order500);
var chainOrder200 = new Chain(order200);
var chainOrderNormal = new Chain(orderNormal);
// 然后指定节点在职责链中的顺序
chainOrder500.setNextSuccessor(chainOrder200);
chainOrder200.setNextSuccessor(chainOrderNormal);
//最后把请求传递给第一个节点:
chainOrder500.passRequest(1, true, 500); // 亲爱的用户,您中奖了100元红包了
chainOrder500.passRequest(2, true, 500); // 亲爱的用户,您中奖了20元红包了
chainOrder500.passRequest(3, true, 500); // 亲爱的用户,您已抽到10元优惠卷
chainOrder500.passRequest(1, false, 0); // 亲爱的用户,请再接再厉哦
</script>
</body>
</html>
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。