JS設計模式之命令模式概念與用法分析,js設計模式

來源:互聯網
上載者:User

JS設計模式之命令模式概念與用法分析,js設計模式

本文執行個體講述了JS設計模式之命令模式概念與用法。分享給大家供大家參考,具體如下:

客戶建立命令;調用者執行該命令;接收者在命令執行時執行相應操作
簡單命令對象一般用來消除二個對象(調用者和接收者)之間的耦合,而複雜的命令對象則一般用來封裝不可分的或事務性的指令。

命令模式的主要用途是把調用對象(使用者介面、API和代理等)與實現操作的對象隔離開。凡是兩個對象間互動方式需要有更高的模組化程度時都可以用到這種模式。

命令的意思是用一個簡單方法或函數去執行和這個命令相關的實際操作。就如同用遙控器開啟電視一樣,只按一個按鍵就可以開啟電視,簡單、方便。它具體的實現操作我們不用關心。那是有電視器來處理的。電視對遙控器提供了一個介面(訊號),遙控器只需要在點擊時實現這個介面就可以了。

Command:
定義命令的介面,聲明執行的方法。
ConcreteCommand:
命令介面實現對象,是“虛”的實現;通常會持有接收者,並調用接收者的功能來完成命令要執行的操作。
Receiver:
接收者,真正執行命令的對象。任何類都可能成為一個接收者,只要它能夠實現命令要求實現的相應功能。
Invoker:
要求命令對象執行請求,通常會持有命令對象,可以持有很多的命令對象。這個是用戶端真正觸發命令並要求命令執行相應操作的地方,也就是說相當於使用命令對象的入口。
Client:
建立具體的命令對象,並且設定命令對象的接收者。注意這個不是我們常規意義上的用戶端,而是在組裝命令對象和接收者,或許,把這個Client稱為裝配者會更好理解,因為真正使用命令的用戶端是從Invoker來觸發執行

模式分析

1.命令模式的本質是對命令進行封裝,將發出命令的責任和執行命令的責任分割開。
2.每一個命令都是一個操作:請求的一方發出請求,要求執行一個操作;接收的一方收到請求,並執行操作。
3.命令模式允許請求的一方和接收的一方獨立開來,使得請求的一方不必知道接收請求的一方的介面,更不必知道請求是怎麼被接收,以及操作是否被執行、何時被執行,以及是怎麼被執行的。
4.命令模式使請求本身成為一個對象,這個對象和其他對象一樣可以被儲存和傳遞。
5.命令模式的關鍵在於引入了抽象命令介面,且寄件者針對抽象命令介面編程,只有實現了抽象命令介面的具體命令才能與接收者相關聯。

模式優點

1.降低對象之間的耦合度。
2.新的命令可以很容易地加入到系統中。
3.可以比較容易地設計一個組合命令。
4.調用同一方法實現不同的功能

// 命令var CreateCommand = function( receiver ){ this.receiver = receiver;}CreateCommand.prototype.execute = function() { this.receiver.action();}// 接收者 電視var TVOn = function() {}TVOn.prototype.action = function() {  alert("TVOn");}// 接收者 電視var TVOff = function() {}TVOff.prototype.action = function() {  alert("TVOff");}// 調用者 遙控器var Invoker = function( tvOnCommand, tvOffCommand ) {  this.tvOnCommand = tvOnCommand;  this.tvOffCommand = tvOffCommand;}Invoker.prototype.tvOn = function() {  this.tvOnCommand.execute();}Invoker.prototype.tvOff = function() {  this.tvOffCommand.execute();}

執行Client

var tvOnCommand = new CreateCommand( new TVOn() );var tvOffCommand = new CreateCommand( new TVOff() );var invoker = new Invoker( tvOnCommand, tvOffCommand );invoker.tvOn();invoker.tvOff();

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.