JS命令模式例子之菜單程序
命令模式的應(yīng)用場景:
有時(shí)候需要向某些對象發(fā)送請求,但是并不知道請求的接收者是誰,也不知道被請求的操作是什么,此時(shí)希望用一種松耦合的方式來設(shè)計(jì)軟件,使得請求發(fā)送者和請求接收者能夠消除彼此之間的耦合關(guān)系。
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">
這是預(yù)設(shè)的內(nèi)容
</textarea>
</body>
</html>
js代碼:
// 在頁面中使用例:setCommand( button1, refreshMenuBarCommand );來發(fā)送命令
// setCommand 函數(shù)負(fù)責(zé)往按鈕上面安裝命令,預(yù)留好安裝命令的接口
var setCommand = function( button , command ){
button.onclick = function(){
command.execute();
}
}
// 編寫點(diǎn)擊按鈕之后的具體行為:刷新菜單界面、增加子菜單和刪除子菜單
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 );
}
總結(jié):
從書上抄代碼練習(xí)的過程中出了很多錯(cuò)誤,最嚴(yán)重的莫過于“receiver”這個(gè)單詞寫錯(cuò)了導(dǎo)致很多天都再沒看這個(gè)練習(xí),出錯(cuò)的過程讓我能夠重新審視代碼的內(nèi)容,逐行進(jìn)行理解與調(diào)試。雖然仍然不很理解命令模式,但是通過這部分的內(nèi)容和對mySQL的學(xué)習(xí),心里隱隱的留下了關(guān)于命令模式的影子。
參考:
《JavaScript設(shè)計(jì)模式與開發(fā)實(shí)踐》第9章9.2節(jié)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JavaScript設(shè)計(jì)模式之命令模式
- javascript設(shè)計(jì)模式 – 命令模式原理與用法實(shí)例分析
- JavaScript命令模式原理與用法實(shí)例詳解
- JavaScript設(shè)計(jì)模式之命令模式實(shí)例分析
- JS設(shè)計(jì)模式之命令模式概念與用法分析
- JavaScript設(shè)計(jì)模式經(jīng)典之命令模式
- 深入理解JavaScript系列(34):設(shè)計(jì)模式之命令模式詳解
- 怎樣用JavaScript實(shí)現(xiàn)原型模式
- 怎樣用JavaScript實(shí)現(xiàn)觀察者模式
- 詳解Javascript實(shí)踐中的命令模式
相關(guān)文章
解決js中的setInterval清空定時(shí)器不管用問題
這篇文章主要介紹了解決js中的setInterval清空定時(shí)器不管用問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
javascript簡單性能問題及學(xué)習(xí)筆記
最近在看一本書:《高性能javaScript》,發(fā)現(xiàn)自己平時(shí)寫js存在很多小細(xì)節(jié)上的問題,雖然這些問題不會導(dǎo)致程序運(yùn)行出錯(cuò),但是會導(dǎo)致界面加載變慢,用戶體驗(yàn)變差,那么我們就來細(xì)細(xì)數(shù)一下應(yīng)該注意的地方吧2014-02-02
window.open以post方式將內(nèi)容提交到新窗口
最近在做web項(xiàng)目,碰到需要跨頁面?zhèn)鬟f參數(shù)的功能,就是那種需要把當(dāng)前頁面的內(nèi)容帶到新開的子窗體中,以前的做法是傳一個(gè)id過去,然后在新窗口中去讀數(shù)據(jù)庫的內(nèi)容;比較有意思的是直接通過調(diào)用form的submit方法不能觸發(fā)onsubmit事件,查看了幫助文檔,必須手動(dòng)的觸發(fā),否則只能看到頁面刷新而沒有打開新窗口2012-12-12
JavaScript實(shí)現(xiàn)x秒后自動(dòng)跳轉(zhuǎn)到一個(gè)頁面
今天看視頻學(xué)習(xí)時(shí)學(xué)習(xí)了一種新技術(shù),即平時(shí)我們在一個(gè)頁面點(diǎn)擊“提交”或“確認(rèn)”會自動(dòng)跳轉(zhuǎn)到一個(gè)頁面,在網(wǎng)上搜了一下,關(guān)于這個(gè)技術(shù)處理有多種方法,有興趣的朋友可以參考下2013-01-01
JavaScript Event學(xué)習(xí)第九章 鼠標(biāo)事件
鼠標(biāo)事件是到目前為止最重要的事件。在這一章我將介紹一些鼠標(biāo)事件的最常見的問題和技巧。2010-02-02
JS與SQL方式隨機(jī)生成高強(qiáng)度密碼示例
這篇文章主要介紹了JS與SQL方式隨機(jī)生成高強(qiáng)度密碼,結(jié)合實(shí)例形式分析了javascript方式與SQL方式生成高強(qiáng)度密碼的相關(guān)操作技巧,需要的朋友可以參考下2018-12-12

