1 Star 0 Fork 0

癫疯丶歌谣/前端牛客网面试题刷题

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
职责链模式220330.html 2.84 KB
一键复制 编辑 原始数据 按行查看 历史
癫疯丶歌谣 提交于 2022-03-30 17:31 . 修改
<!--
* @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>
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/geyaoisgeyao/geyao.git
git@gitee.com:geyaoisgeyao/geyao.git
geyaoisgeyao
geyao
前端牛客网面试题刷题
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385