博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS:命令模式的例子——菜单程序
阅读量:6032 次
发布时间:2019-06-20

本文共 2018 字,大约阅读时间需要 6 分钟。

hot3.png

命令模式的应用场景:

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

html代码:

	
js:命令模式

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的学习,心里隐隐的留下了关于命令模式的影子。

 

参考:

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

转载于:https://my.oschina.net/u/1165991/blog/756164

你可能感兴趣的文章
android--------阿里 AndFix 热修复
查看>>
java springcloud版b2b2c社交电商spring cloud分布式微服务 (七)高可用的分布式配置中心(Spring Cloud Config)...
查看>>
Oozie与Coordinator调度讲解及系统时区配置与定时触发两种配置方式
查看>>
RGB_YUV_YCbCr
查看>>
tesseract 安装及使用
查看>>
优化SqlServer--数据压缩
查看>>
SharePoint 自定义WebPart之间的连接
查看>>
231. Power of Two
查看>>
control.add()
查看>>
p点到(a,b)点两所在直线的垂点坐标及p点是否在(a,b)两点所在直线上
查看>>
GridView强制换行与自动换行
查看>>
51Nod 1003 阶乘后面0的数量(数学,思维题)
查看>>
Sublime text3中配置Github
查看>>
Getting Started with iOS Development Part10:Customizing your Mobile target's Splash screen
查看>>
asp.net C# MVC 提交表单后清空表单
查看>>
备份软件 FreeFileSync 怎么用
查看>>
Asp.net,C# 加密解密字符串
查看>>
网页视频播放器插件源码
查看>>
CentOS7 睡眠 休眠 关机 电源
查看>>
SqlServer里DateTime转字符串
查看>>