日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript命令模式原理與用法實例詳解

瀏覽:141日期:2023-11-07 16:05:57

本文實例講述了JavaScript命令模式原理與用法。分享給大家供大家參考,具體如下:

第一,命令模式: (1)用于消除調用者和接收者之間直接的耦合的模式,并且可以對(調用這個過程進行留痕操作)

(2)真的不要亂用這個模式,以為他使你簡單調用寫法變得非常的復雜和有些難以理解。(3)你的業務出現了 (回退操作)(重做操作)的需求的時候你就要考慮使用這個模式了。命令的原理:JavaScript命令模式原理與用法實例詳解

一種情況為發出者直接作用于執行者,這樣耦合度很高,另外一種情況為,在發出者和執行者之間增加一個用存儲命令的命令訪問庫也即命令命令模式。第二,現在我們通過一個需求來學習該模式需求為:

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='http://www.b3g6.com/bcjs/Js/設計模式第三部分/命令模式/keymaster.min.js'></script><script src='http://www.b3g6.com/bcjs/Js/設計模式第三部分/命令模式/uuid.js'></script><script src='http://www.b3g6.com/bcjs/Js/設計模式第三部分/命令模式/(18)命令模式.js'></script></body>

效果為,JavaScript命令模式原理與用法實例詳解

根據上述圖我們逐步完成步驟一,定義主應用程序----接收者

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 under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, 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

感興趣的朋友可以使用在線HTML/CSS/JavaScript前端代碼調試運行工具:http://tools.jb51.net/code/WebCodeRun測試上述代碼運行效果。

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

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

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
91看片一区| 视频一区二区中文字幕| 蜜臀精品一区二区三区在线观看| 视频在线观看91| 久久视频精品| a国产在线视频| 久久精品卡一| 99国产精品久久久久久久| 不卡av一区二区| 亚洲一区二区三区高清| 影音先锋久久精品| 欧美视频二区| 久久麻豆视频| 精品国产午夜肉伦伦影院| 亚洲黄色免费av| 伊人久久婷婷| 欧美在线日韩| 欧美国产美女| 婷婷综合五月| 日韩在线视频一区二区三区| 日本亚洲欧洲无免费码在线| 欧美精品91| 国产精品一区免费在线| 国产精品magnet| 久久91视频| 在线国产一区| 亚洲精品极品| 美女久久久精品| 日本久久黄色| 日韩动漫一区| 三级欧美韩日大片在线看| 国产在线观看91一区二区三区| 欧美1级日本1级| 成人日韩av| 日韩欧美高清一区二区三区| 亚洲一区区二区| 国产精品精品| 国产精品一卡| 蜜臀av国产精品久久久久| 欧美国产偷国产精品三区| 国产日韩欧美三级| 免费成人在线观看| 蜜臀91精品国产高清在线观看| 国产精品亚洲四区在线观看| 一区久久精品| 91精品精品| 精品久久福利| 久久99视频| 国产精品大片| 国产福利一区二区精品秒拍| 噜噜噜久久亚洲精品国产品小说| 国产高潮在线| 精品72久久久久中文字幕| 国产精品一级| 欧美国产极品| 国产精品久久久免费| 久久超碰99| 成人在线黄色| av高清不卡| 亚洲精品成人| 一区二区精品| 久久精品72免费观看| 国产精品一区二区精品视频观看| 国产精品一区二区三区www| 国产精品美女久久久久久不卡| 综合在线一区| 国产精品调教| 日韩欧美看国产| 九一国产精品| 亚洲区第一页| 久久99国产精品视频| 亚洲精品.com| 亚洲毛片网站| 日本午夜精品一区二区三区电影| 97久久中文字幕| 成人免费电影网址| 视频在线观看一区| 国产日韩精品视频一区二区三区| 丁香婷婷久久| 喷白浆一区二区| 国产成人久久| 久热精品在线| 国产成人免费精品| 视频一区二区不卡| 91一区二区三区四区| 91av亚洲| 欧美在线看片| 欧美日韩国产高清| 国产精品玖玖玖在线资源| 99久久婷婷| 国产一精品一av一免费爽爽| 吉吉日韩欧美| 欧美亚洲人成在线| 人人爽香蕉精品| 亲子伦视频一区二区三区| 日韩精品一级二级| 欧美精品激情| 久久蜜桃av| 日本不卡一区二区三区| 精品网站aaa| 午夜一区在线| 麻豆91精品视频| 日韩在线一二三区| 国内揄拍国内精品久久| 天堂成人免费av电影一区| 久久久91麻豆精品国产一区| 欧美日韩国产综合网| 国产精品4hu.www| 日韩精品一卡二卡三卡四卡无卡| 国内在线观看一区二区三区| 不卡视频在线| 亚洲黄色中文字幕| 国产麻豆一区二区三区精品视频| 欧美日韩国产综合网| 黄色aa久久| 国产成人精品三级高清久久91| 中文字幕av一区二区三区四区| 欧美二区视频| 日韩和的一区二在线| 国产福利91精品一区二区| 欧美一区在线观看视频| 国产手机视频一区二区 | 国产高清精品二区| 久久亚洲色图| 一区二区视频欧美| 免费视频一区三区| 亚洲午夜精品久久久久久app| 日韩精品1区| 国产不卡av一区二区| 久久久免费人体| 黄色精品视频| 激情亚洲影院在线观看| 久久uomeier| 婷婷亚洲综合| 中文字幕乱码亚洲无线精品一区| 丝袜亚洲精品中文字幕一区| 欧美成人国产| 在线观看亚洲精品福利片| 91九色精品| 亚洲精品在线a| 国产欧美日韩精品高清二区综合区 | 欧美男人天堂| 精品亚洲a∨一区二区三区18| 国产极品模特精品一二| 国产精品亚洲产品| av中文资源在线资源免费观看| 亚洲成人一区在线观看| 香蕉久久国产| 日韩超碰人人爽人人做人人添| 精品淫伦v久久水蜜桃| 成人羞羞在线观看网站| 欧美成人综合| 91成人在线| 亚洲最新无码中文字幕久久| 久久国产亚洲| 婷婷精品在线观看| 国产欧洲在线| 亚洲精品极品| 四季av一区二区凹凸精品| 中文一区一区三区高中清不卡免费| 国产一区二区亚洲| 一本一本久久| 国产精品片aa在线观看| 久久久精品五月天| 日韩高清二区| 亚洲特色特黄| 日本aⅴ亚洲精品中文乱码| 欧美日韩精品免费观看视完整| 日韩区欧美区| 成人羞羞视频播放网站| 91精品国产自产精品男人的天堂| 国产一区二区三区不卡视频网站| 99亚洲视频| 欧美激情一区| 99视频精品全国免费| 日本伊人久久| 欧美亚洲国产一区| 亚洲精品高潮| 欧美福利在线| 精品国产亚洲日本| 美女国产一区| 97精品中文字幕| 午夜精品福利影院| 久久久久国产精品一区二区| 国产日本亚洲| 亚洲精品自拍| 国产综合精品| 麻豆精品在线观看| 亚洲精品福利| 成人日韩在线观看| 国产欧美亚洲精品a| 91久久视频| 亚洲国产专区校园欧美| 欧美国产另类| 日韩精品亚洲专区| 午夜亚洲福利| 天堂久久一区| 日韩av中文字幕一区二区三区| 91亚洲国产| 欧美日韩一区自拍|