JS命令模式例子之菜单程序


Posted in Javascript onOctober 10, 2016

命令模式的应用场景:

        有时候需要向某些对象发送请求,但是并不知道请求的接收者是谁,也不知道被请求的操作是什么,此时希望用一种松耦合的方式来设计软件,使得请求发送者和请求接收者能够消除彼此之间的耦合关系。

html代码:

<!DOCTYPE html>
<html>
<head>
 <meta charset="utf-8" />
 <title>js:命令模式</title>
 <script type="text/javascript" src="command.js"></script>
</head>
<style type="text/css">
button{
 margin: 5px;
 border: 0;
 width: 70px;
 height: 35px;
 background: #6B78BF;
 color: white;
 font-size: 14px;
 font-family: "微软雅黑";
 cursor: pointer;
}
#textarea{
 margin: 5px;
 width: 400px;
 height: 200px;
 resize: none;
 color: #666;
 font-size: 14px;
 border: 2px solid #6B78BF;
}
</style>
<body>
<button id="button1">刷新</button>
<button id="button2">新增</button>
<button id="button3">删除</button>
<br/>
<textarea id="textarea">
这是预设的内容
</textarea>

</body>
</html>

js代码:

// 在页面中使用例:setCommand( button1, refreshMenuBarCommand );来发送命令


// setCommand 函数负责往按钮上面安装命令,预留好安装命令的接口
var setCommand = function( button , command ){
 button.onclick = function(){
 command.execute();
 }
}

// 编写点击按钮之后的具体行为:刷新菜单界面、增加子菜单和删除子菜单
var MenuBar = {
 refresh: function(){
 var cur_date = new Date();
 document.getElementById("textarea").value+=cur_date.toLocaleString()+" 刷新菜单目录\r";
 }
}
var SubMenu = {
 add: function(){
 var cur_date = new Date();
 document.getElementById("textarea").value+=cur_date.toLocaleString()+" 新增菜单目录\r";
 },
 del: function(){
 var cur_date = new Date();
 document.getElementById("textarea").value+=cur_date.toLocaleString()+" 删除子菜单\r";
 }
}

//封装行为在命令类中
var RefreshMenuBarCommand = function( receiver ){
 this.receiver = receiver;

}
RefreshMenuBarCommand.prototype.execute = function(){
 this.receiver.refresh();
}
var AddSubMenuCommand = function( receiver ){
 this.receiver = receiver;
}
AddSubMenuCommand.prototype.execute = function(){
 this.receiver.add();
}
var DelSubMenuCommand = function( receiver ){
 this.receiver =receiver
}
DelSubMenuCommand.prototype.execute = function(){
 this.receiver.del();
}

//命令接收者传入到 command 对象
var refreshMenuBarCommand = new RefreshMenuBarCommand( MenuBar );
var addSubMenuCommand = new AddSubMenuCommand( SubMenu );
var delSubMenuCommand = new DelSubMenuCommand( SubMenu );

window.onload = function(){
 //把 command 对象安装到 button 上面
 var button1 = document.getElementById("button1");
 var button2 = document.getElementById("button2");
 var button3 = document.getElementById("button3");
 setCommand( button1, refreshMenuBarCommand );
 setCommand( button2, addSubMenuCommand );
 setCommand( button3, delSubMenuCommand );
}

总结:

从书上抄代码练习的过程中出了很多错误,最严重的莫过于“receiver”这个单词写错了导致很多天都再没看这个练习,出错的过程让我能够重新审视代码的内容,逐行进行理解与调试。虽然仍然不很理解命令模式,但是通过这部分的内容和对mySQL的学习,心里隐隐的留下了关于命令模式的影子。

参考:

《JavaScript设计模式与开发实践》第9章9.2节

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS两种定义方式的区别、内部原理
Nov 21 Javascript
js随机生成26个大小写字母
Feb 12 Javascript
jquery使用Cookie和JSON记录用户最近浏览历史
Apr 19 Javascript
Bootstrap+jfinal实现省市级联下拉菜单
May 30 Javascript
响应式表格之固定表头的简单实现
Aug 26 Javascript
关于vue-router路径计算问题
May 10 Javascript
动态加载权限管理模块中的Vue组件
Jan 16 Javascript
javascript和php使用ajax通信传递JSON的实例
Aug 21 Javascript
jQuery+css last-child实现选择最后一个子元素操作示例
Dec 10 jQuery
vue如何自动化打包测试环境和正式环境的dist/test文件
Jun 06 Javascript
vue-cli3项目展示本地Markdown文件的方法
Jun 07 Javascript
Vue2.0实现简单分页及跳转效果
Jul 29 Javascript
KnockoutJS 3.X API 第四章之数据控制流component绑定
Oct 10 #Javascript
KnockoutJS 3.X API 第四章之click绑定
Oct 10 #Javascript
KnockoutJS 3.X API 第四章之事件event绑定
Oct 10 #Javascript
KnockoutJS 3.X API 第四章之表单submit、enable、disable绑定
Oct 10 #Javascript
让浏览器崩溃的12行JS代码(DoS攻击分析及防御)
Oct 10 #Javascript
KnockoutJS 3.X API 第四章之表单value绑定
Oct 10 #Javascript
jquery操作checkbox火狐下第二次无法勾选的解决方法
Oct 10 #Javascript
You might like
PHP执行linux系统命令的常用函数使用说明
2010/04/27 PHP
PHP中shuffle数组值随便排序函数用法
2014/11/21 PHP
PHP实现批量修改文件后缀名的方法
2015/07/30 PHP
Laravel 5.4向IoC容器中添加自定义类的方法示例
2017/08/15 PHP
讲两件事:1.this指针的用法小探. 2.ie的attachEvent和firefox的addEventListener在事件处理上的区别
2007/04/12 Javascript
ExtJS 入门
2010/10/29 Javascript
基于JavaScript 类的使用详解
2013/05/07 Javascript
Firefox和IE兼容性问题及解决方法总结
2013/10/08 Javascript
jquery五角星评分插件示例分享
2014/02/21 Javascript
javascript实现一个数值加法函数
2015/06/26 Javascript
AngularJS中$interval的用法详解
2016/02/02 Javascript
jquery ajax结合thinkphp的getjson实现跨域的方法
2016/06/06 Javascript
jQuery实现每隔几条元素增加1条线的方法
2016/06/27 Javascript
JavaScript关于提高网站性能的几点建议(一)
2016/07/24 Javascript
在web中js实现类似excel的表格控件
2016/09/01 Javascript
js制作简单的音乐播放器的示例代码
2017/08/28 Javascript
Angular4绑定html内容出现警告的处理方法
2017/11/03 Javascript
angular2中使用第三方js库的实例
2018/02/26 Javascript
Node.js中Koa2在控制台输出请求日志的方法示例
2019/05/02 Javascript
微信小程序webview 脚手架使用详解
2019/07/22 Javascript
JS实现页面侧边栏效果探究
2021/01/08 Javascript
[15:58]DOTA2国际邀请赛采访专栏:Tongfu.Sansheng&KingJ,DK.rOtk
2013/08/08 DOTA
[10:14]2018DOTA2国际邀请赛寻真——paiN Gaming不仅为自己而战
2018/08/14 DOTA
python简单实现刷新智联简历
2016/03/30 Python
python中类和实例如何绑定属性与方法示例详解
2017/08/18 Python
Python数据可视化正态分布简单分析及实现代码
2017/12/04 Python
python实现周期方波信号频谱图
2018/07/21 Python
python使用递归的方式建立二叉树
2019/07/03 Python
opencv 获取rtsp流媒体视频的实现方法
2019/08/23 Python
Python TKinter如何自动关闭主窗口
2020/02/26 Python
10 套华丽的CSS3 按钮小结
2012/10/03 HTML / CSS
香奈儿美国官网:CHANEL美国
2020/05/20 全球购物
合伙协议书范本
2014/04/21 职场文书
英语教师自荐信
2014/05/26 职场文书
政法干警核心价值观心得体会
2014/09/11 职场文书
房产遗嘱范本
2015/08/06 职场文书