亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript設計模式之命令模式實例分析

2019-11-19 12:17:04
字體:
來源:轉載
供稿:網友

本文實例講述了JavaScript設計模式之命令模式。分享給大家供大家參考,具體如下:

第一,命令模式:

(1)用于消除調用者和接收者之間直接的耦合的模式,并且可以對(調用這個過程進行留痕操作)
(2)真的不要亂用這個模式,以為他使你簡單調用寫法變得非常的復雜和有些難以理解。
(3)你的業務出現了 (回退操作)(重做操作)的需求的時候你就要考慮使用這個模式了。

命令的原理:

一種情況為發出者直接作用于執行者,這樣耦合度很高,另外一種情況為,在發出者和執行者之間增加一個用存儲命令的命令訪問庫也即命令命令模式。

第二,現在我們通過一個需求來學習該模式

需求為:

1.有一個"添加流程的按鈕"單擊的時候 就會添加一個新的文本當做流程的描述

2.有"返回","重做" 2個按鈕來完成相應的任務。

第三,界面為

<body><input type="text" id="flow"><input type="button" value="添加新流程" onclick="API.addFlow()"><br><input type="button" value="ctrl+z回退" onclick="API.ret()"><input type="button" value="ctrl+z+x重做" onclick="API.again()"><div id= "div01"></div><script src="Js/設計模式第三部分/命令模式/keymaster.min.js"></script><script src="Js/設計模式第三部分/命令模式/uuid.js"></script><script src="Js/設計模式第三部分/命令模式/(18)命令模式.js"></script></body>

效果為,

根據上述圖我們逐步完成

步驟一,定義主應用程序----接收者

function manager() {    this.addFlow=function (id,value) {        //1.得到目標節點      var div=document.getElementById("div01");      var newFlow=document.createElement("div");      newFlow.setAttribute("id",id);      newFlow.innerHTML=value;      div.appendChild(newFlow);    }}

步驟二,為對象(執行者)建立命令訪問庫 ---意思是可以通過extcute方法訪問到addFlow方法

manager.prototype.extcute=(function () {  /*command 命令對象  * */  return function (command) {    return this[command.method](command.id,command.value);  }})();

步驟三,初始化主類

var ma = new manager();//可以用該對象,調用其的東西//用于存儲"調用對象命令的"集合var commands = new Array();//集合的游標--初始化在末尾var index = commands.length;

步驟四,客戶端----發出者

var API=function () {   this.addFlow=function () {     //把調用封裝起來     var command={       method:"addFlow",       id:new UUID().createUUID(),//產生id的插件       value:document.getElementById("flow").value     };     //把調用對象保存起來,用于回退和重做作用     commands.push(command);     //重新定位游標---賦值記錄     index = commands.length;     //調用     ma.extcute(command);   };   /**    * 用于返回的方法    */   this.ret=function () {     if(index-1<0){       alert("已經到了最后一步了...");     }else {       var all=document.getElementById("div01").childNodes;       document.getElementById("div01").removeChild(all[all.length-1]);       index=index-1;     }   };   /**    * 用于重做的方法    */   this.again=function () {     if(index>=commands.length){       alert("已經到了最前面一步了,不能進行重做...");     }else {       var command=commands[index];//獲取當前的命令位置       ma.extcute(command);       index=index+1;     }   }}

步驟五,實例化客戶端

API=new API();//實例化

這樣html中的事件就可以起作用了。

在這里我們使用插件來讓其功能支持自定義的鍵盤事件,插件名稱為:keymaster.js

首先,如html中一樣引入文件,

然后值調用key添加自定義的鍵盤事件

//添加支持ctrl+z--返回key("ctrl+z",function () {  API.ret();});//重做---key("ctrl+shift+x",function () {  API.again();})

為此我們可以使用鍵盤的指定組合實現和鼠標點擊一樣的效果。

這里需要說明一下客戶端的API中的id值,也是通過插件來動態生成的------插件名稱為:uuid.js。這里附上源碼

/*uuid.js - Version 0.2JavaScript Class to create a UUID like identifierCopyright (C) 2006-2008, Erik Giberti (AF-Design), All rights reserved.This program is free software; you can redistribute it and/or modify it underthe terms of the GNU General Public License as published by the Free SoftwareFoundation; either version 2 of the License, or (at your option) any laterversion.This program is distributed in the hope that it will be useful, but WITHOUT ANYWARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR APARTICULAR PURPOSE. See the GNU General Public License for more details.You should have received a copy of the GNU General Public License along withthis program; if not, write to the Free Software Foundation, Inc., 59 TemplePlace, Suite 330, Boston, MA 02111-1307 USAThe latest version of this file can be downloaded fromhttp://www.af-design.com/resources/javascript_uuid.phpHISTORY:6/5/06   - Initial Release5/22/08 - Updated code to run faster, removed randrange(min,max) in favor of     a simpler rand(max) function. Reduced overhead by using getTime()     method of date class (suggestion by James Hall).KNOWN ISSUES:- Still no way to get MAC address in JavaScript- Research into other versions of UUID show promising possibilities (more research needed)- Documentation needs improvement*/// On creation of a UUID object, set it's initial valuefunction UUID(){  this.id = this.createUUID();}// When asked what this Object is, lie and return it's valueUUID.prototype.valueOf = function(){ return this.id; }UUID.prototype.toString = function(){ return this.id; }//// INSTANCE SPECIFIC METHODS//UUID.prototype.createUUID = function(){  //  // Loose interpretation of the specification DCE 1.1: Remote Procedure Call  // described at http://www.opengroup.org/onlinepubs/009629399/apdxa.htm#tagtcjh_37  // since JavaScript doesn't allow access to internal systems, the last 48 bits  // of the node section is made up using a series of random numbers (6 octets long).  //  var dg = new Date(1582, 10, 15, 0, 0, 0, 0);  var dc = new Date();  var t = dc.getTime() - dg.getTime();  var h = '-';  var tl = UUID.getIntegerBits(t,0,31);  var tm = UUID.getIntegerBits(t,32,47);  var thv = UUID.getIntegerBits(t,48,59) + '1'; // version 1, security version is 2  var csar = UUID.getIntegerBits(UUID.rand(4095),0,7);  var csl = UUID.getIntegerBits(UUID.rand(4095),0,7);  // since detection of anything about the machine/browser is far to buggy,  // include some more random numbers here  // if NIC or an IP can be obtained reliably, that should be put in  // here instead.  var n = UUID.getIntegerBits(UUID.rand(8191),0,7) +      UUID.getIntegerBits(UUID.rand(8191),8,15) +      UUID.getIntegerBits(UUID.rand(8191),0,7) +      UUID.getIntegerBits(UUID.rand(8191),8,15) +      UUID.getIntegerBits(UUID.rand(8191),0,15); // this last number is two octets long  return tl + h + tm + h + thv + h + csar + csl + h + n;}//// GENERAL METHODS (Not instance specific)//// Pull out only certain bits from a very large integer, used to get the time// code information for the first part of a UUID. Will return zero's if there// aren't enough bits to shift where it needs to.UUID.getIntegerBits = function(val,start,end){  var base16 = UUID.returnBase(val,16);  var quadArray = new Array();  var quadString = '';  var i = 0;  for(i=0;i<base16.length;i++){    quadArray.push(base16.substring(i,i+1));  }  for(i=Math.floor(start/4);i<=Math.floor(end/4);i++){    if(!quadArray[i] || quadArray[i] == '') quadString += '0';    else quadString += quadArray[i];  }  return quadString;}// Numeric Base Conversion algorithm from irt.org// In base 16: 0=0, 5=5, 10=A, 15=FUUID.returnBase = function(number, base){  //  // Copyright 1996-2006 irt.org, All Rights Reserved.  //  // Downloaded from: http://www.irt.org/script/146.htm  // modified to work in this class by Erik Giberti  var convert = ['0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'];  if (number < base) var output = convert[number];  else {    var MSD = '' + Math.floor(number / base);    var LSD = number - MSD*base;    if (MSD >= base) var output = this.returnBase(MSD,base) + convert[LSD];    else var output = convert[MSD] + convert[LSD];  }  return output;}// pick a random number within a range of numbers// int b rand(int a); where 0 <= b <= aUUID.rand = function(max){  return Math.floor(Math.random() * max);}// end of UUID class file

更多關于JavaScript相關內容還可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲欧美日韩一区二区| 欧美日韩亚洲国产一区| 精品亚洲va在线va天堂资源站| 精品免费在线视频| 国产欧美一区二区三区在线| 久久99国产精品久久久久久久久| 8090成年在线看片午夜| 国产欧美 在线欧美| 九九九久久国产免费| 亚洲欧美一区二区三区四区| 九色成人免费视频| 国内成人精品一区| 91香蕉嫩草神马影院在线观看| 一本色道久久88综合日韩精品| 国产日韩在线一区| 国产美女主播一区| 亚洲成人精品久久| 国产偷亚洲偷欧美偷精品| 国产一区二区三区欧美| 欧美成aaa人片免费看| 国产精品久久久久久久久免费| 欧美国产亚洲精品久久久8v| 国产一区二区在线免费视频| 亚洲毛片在线观看| 91影视免费在线观看| 久久精彩免费视频| 亚洲第一综合天堂另类专| 欧美性极品xxxx娇小| 91亚洲精品久久久| 成人春色激情网| 国产噜噜噜噜噜久久久久久久久| 国产精品流白浆视频| 在线播放国产精品| 欧美黑人极品猛少妇色xxxxx| 国产精品扒开腿做爽爽爽的视频| 亚洲精品国产拍免费91在线| 成人免费网站在线看| 综合网日日天干夜夜久久| 97精品久久久中文字幕免费| 亚洲国产第一页| 国产精品美女免费看| 日韩美女福利视频| 久久久久久成人精品| 中文字幕一区日韩电影| 日韩的一区二区| 国产精品久久久| 日韩精品免费在线视频观看| 日本午夜精品理论片a级appf发布| 97视频在线观看网址| 国产精品扒开腿做爽爽爽的视频| www.久久草.com| 亚洲电影天堂av| 亚洲精品www久久久久久广东| 久久久久久久香蕉网| 国产成人午夜视频网址| 日本国产欧美一区二区三区| 日韩精品在线私人| 欧美一乱一性一交一视频| 亚洲国产欧美一区二区三区久久| 日韩视频永久免费观看| 亚洲а∨天堂久久精品9966| 蜜臀久久99精品久久久无需会员| 色视频www在线播放国产成人| 中文字幕在线精品| 日本亚洲欧洲色α| 色婷婷av一区二区三区久久| 久久精品国产久精国产一老狼| 国产精品久久久91| 久久久久北条麻妃免费看| 欧美日韩中文字幕日韩欧美| 亚洲国产成人av在线| 91系列在线观看| 精品国产999| 亚洲欧洲中文天堂| 狠狠久久亚洲欧美专区| 亚洲高清在线观看| 精品久久中文字幕| 日韩av在线免费看| 91av在线影院| 亚洲国产欧美精品| 青青精品视频播放| 日韩一区二区欧美| 日韩成人久久久| 欧美做爰性生交视频| 欧美激情一区二区三区成人| 26uuu另类亚洲欧美日本老年| 国产亚洲一区精品| 欧美日韩国产中字| 欧美猛少妇色xxxxx| 欧美中文字幕精品| 亚洲综合小说区| 97国产精品视频人人做人人爱| 亚洲精品www久久久久久广东| 精品久久久久久久久久国产| 亚洲91精品在线| 亚洲欧洲日产国码av系列天堂| 久久精品亚洲精品| 日本sm极度另类视频| 国产91亚洲精品| 亚洲精品久久久一区二区三区| 欧美大全免费观看电视剧大泉洋| 91亚洲国产成人久久精品网站| 精品欧美aⅴ在线网站| 亚洲免费精彩视频| 欧美色xxxx| 91日韩在线播放| 亚洲欧美精品中文字幕在线| 亚洲大尺度美女在线| 国产综合久久久久久| 亚洲第一区第二区| 久久色免费在线视频| yw.139尤物在线精品视频| 日韩av在线网站| 蜜臀久久99精品久久久无需会员| 国产精品女主播| 在线视频日韩精品| 国产一区二区三区日韩欧美| 国产最新精品视频| 96精品久久久久中文字幕| 91九色视频在线| 国产精品69精品一区二区三区| 69**夜色精品国产69乱| 欧美精品一区二区免费| 国产精品美女www爽爽爽视频| 国产精品夫妻激情| 国产男人精品视频| 亚洲精品永久免费精品| 亚洲国产日韩欧美在线99| 日韩大片免费观看视频播放| 日韩欧美在线观看视频| 亚洲精品xxxx| 97婷婷大伊香蕉精品视频| 日本中文字幕成人| 亚洲国产精彩中文乱码av| 国产91av在线| 青青草99啪国产免费| 亚洲美女av电影| 欧美精品在线视频观看| 国产在线观看一区二区三区| 欧美激情精品久久久| 亚洲精品99久久久久| 韩国三级电影久久久久久| 久久久久亚洲精品| 日韩av一区在线| 欧美与欧洲交xxxx免费观看| 国产精品久久久久久久久免费看| 在线播放国产一区中文字幕剧情欧美| 午夜精品国产精品大乳美女| 国产精品国产三级国产aⅴ浪潮| 午夜精品久久久久久久白皮肤| 一区二区三区国产在线观看| 国产精品稀缺呦系列在线| 伊人久久久久久久久久| 97在线视频一区| 91国自产精品中文字幕亚洲| 色妞在线综合亚洲欧美| 国产精品久久中文| 日韩av综合网| 国产在线不卡精品| 国产欧美va欧美va香蕉在| 麻豆一区二区在线观看| 欧美日韩亚洲一区二| 久久人人爽人人爽人人片亚洲| 欧美富婆性猛交|