• 售前

  • 售后

热门帖子
入门百科

JavaScript计划模式之下令模式

[复制链接]
jimmy肖明 显示全部楼层 发表于 2021-10-26 14:30:50 |阅读模式 打印 上一主题 下一主题
命令模式是JavaScript设计模式中举动型的一种设计模式;
界说:向某些对象发送哀求,但是并不知道被哀求的操纵具体是什么,以是我们希望以一种松耦合的方式来设计步调,使得哀求发送者和吸取者之间能够消除相互之间的耦合关系;而我们的这种松耦合的方式就是命令模式;
白话表明:假如你是你们公司研发部分团队leader,这时你们领导分布给你一个任务,你大略的看了一下,很简单的需求比较容易实现;而你作为团队leader,天天肯定会有很多事变,以是你准备把需求直接丢给组员去开发和实现;领导根本不在意是你做的照旧你让谁做的,领导要的只是终极效果!这里领导就是命令的发布者,而你就是命令的吸取者;
代码实现:
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6.     <meta http-equiv="X-UA-Compatible" content="ie=edge">
  7.     <title>Document</title>
  8. </head>
  9. <body>
  10.         <button id="button1">发布命令给前端</button>
  11.         <button id="button2">发布命令给后台</button>
  12. </body>
  13. <script>
  14.     var button1 = document.getElementById("button1");
  15.     var button2 = document.getElementById("button2");
  16.     // 定义命令
  17.     var command = function(Executor,func){
  18.         Executor.onclick = func;
  19.     }
  20.     // 定义领导
  21.     var Leader = {};
  22.    
  23.     Leader.teamleader = {
  24.         web:function(){
  25.             console.log("前端马上完成");
  26.         },
  27.         java:function(){   
  28.             console.log("后台马上完成")
  29.         }
  30.     }
  31.     command(button1,Leader.teamleader.web);
  32.     command(button2,Leader.teamleader.java);
  33. </script>
  34. </html>
复制代码
运行效果:

这里的将命令对象单独的界说为一个方法,根据参数执行不同的任务。点击不同按钮的时候,执行不同的命令;
宏命令:
宏命令是一组命令的集合,通过执行宏命令的方式可以一次性执行一批命令;
电脑开机自启动项:现在很多软件都默认添加了电脑开机自启动,就是我们电脑开机之后默认启动某些特定的软件;这就是一种宏命令的场景;
  1. var QQCommand = {
  2.     excute:function(){
  3.         console.log("自启动QQ成功");
  4.     }
  5. }
  6. var weChatCommand = {
  7.     excute:function(){
  8.         console.log("自启动微信成功");
  9.     }
  10. }
  11. var MacroCommand = function(){
  12.     return {
  13.         list:[],
  14.         add:function(command){
  15.             this.list.push(command);
  16.         },
  17.         excute:function(){
  18.             for(var i = 0,command;command = this.list[i++];){
  19.                 command.excute();
  20.             }
  21.         }
  22.     }
  23. }
  24. var macroCommand = MacroCommand();
  25. macroCommand.add(QQCommand);
  26. macroCommand.add(weChatCommand);
  27. macroCommand.excute();
复制代码
上面的代码中,我们在宏命令对象中界说了一个list数组,然后通过add方法进行添加到执行队列中,所谓的执行队列就是list这个数组,然后我们通过循环来依次执行命令,这就产生了我们的宏命令,通过一个命令一键启动多个任务;
命令模式实在就是界说一个命令对象,哀求发布者通过参数化的情势传入参数来进行执行具体不同的操纵,来到达哀求发布者与吸取者的解耦;
最后的话:
本系列一共写了十篇常用的JavaScript设计模式的文章,参考了大量的资料加上本身的明确希望以最通俗易懂的方式来讲给大家听,由于本人水平和精神有限,明确有误的地方请实时指出,设计模式系列文章暂时先搁置,后续再增补;下个月开始准备系统学习ES6,完成ES6系列文章;
以上就是JavaScript设计模式之命令模式的具体内容,更多关于JavaScript设计模式的资料请关注脚本之家其它相干文章!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作