輕鬆掌握:JavaScript模板方法模式

来源:http://www.cnblogs.com/susufufu/archive/2016/08/26/5811054.html
-Advertisement-
Play Games

模板方法模式 假如我們有一些對象,各個對象之間有一些相同的行為,也有一些不同的行為,這時,我們就可以用模板方法模式來把相同的部分上移到它們的共同原型中(父類),而將不同的部分留給自己各自重新實現。 模板方法:在這些平行對象的共同原型中定義的一個方法,它封裝了子類的演算法框架,它作為一個演算法的模板,指導 ...


模板方法模式

假如我們有一些對象,各個對象之間有一些相同的行為,也有一些不同的行為,這時,我們就可以用模板方法模式來把相同的部分上移到它們的共同原型中(父類),而將不同的部分留給自己各自重新實現。

模板方法:在這些平行對象的共同原型中定義的一個方法,它封裝了子類的演算法框架,它作為一個演算法的模板,指導子類以何種順序去執行哪些方法。

模板方法常常被架構師用於搭建項目的框架,架構師定好了框架的骨架,程式員們繼承框架的結構後,負責往裡面填空。

模板方法模式中,常常用到一個鉤子方法:在父類中的容易變化的方法上放置鉤子,模板方法依據鉤子方法的返回值來決定是否執行容易變化的方法。

模板方法模式是一種基於繼承的設計模式,但在JavaScript中也可以通過高階函數來實現。
基於繼承的模板方法模式:

//模板方法模式
//泡茶和沖咖啡,有相似的方法,也有不同的方法
//相似的方法在父類中實現,不同的方法在子類中各自重寫
var Beverage = function () {};
Beverage.prototype.boilWater = function () {
    console.log('把水煮沸');
};
Beverage.prototype.pourMaterial = function (material) {
    console.log('把'+material+'倒進杯子');
};
Beverage.prototype.pourInCup = function () {
    console.log('把沸水倒進杯子');
};
Beverage.prototype.addCondiments = function () {
    throw new Error('子類必須自行實現該方法');
};
//鉤子方法,是否需要加配料
Beverage.prototype.isWantCondiments = function () {
    return true; //預設為true,子類自行實現來改變返回值
};
//模板方法,規定了各個方法的執行順序
Beverage.prototype.init = function (material) {
    this.boilWater();
    this.pourMaterial(material);
    this.pourInCup();
    if(this.isWantCondiments()){  //根據鉤子方法的返回值決定是否執行
        this.addCondiments();
    }
};
//====子類
var Coffee = function () {};
Coffee.prototype = new Beverage(coffee);
Coffee.prototype.addCondiments = function () {
    console.log('加糖');
};
Coffee.prototype.isWantCondiments = function () {
    return window.confirm('請問需要加糖嗎?');
};
//調用
var coffee = '咖啡粉';
var coffee1 = new Coffee();
coffee1.init(coffee);

通過高階函數來實現:

var Beverage1 = function (obj,material) {
    var boilWater = function(){
        console.log('把水煮沸');
    };
    var pourMaterial = function(material){
        console.log('把'+material+'倒進杯子');
    };
    var pourInCup = function () {
        console.log('把沸水倒進杯子');
    };
    var addCondiments = obj.addCondiments||function () {
        throw new Error('子類必須自行實現該方法');
    };
    var isWantCondiments = obj.isWantCondiments||function () {
        return true; //預設為true,子類自行實現來改變返回值
    };
    var F = function(){};
    F.prototype.init = function(){
        boilWater();
        pourMaterial(material);
        pourInCup();
        if(isWantCondiments()){  //根據鉤子方法的返回值決定是否執行
            addCondiments();
        }
    };
    return F;
};
//定義子類
var Coffee1 = Beverage1({
    addCondiments: function(){
        console.log('加糖');
    },
    isWantCondiments: function () {
        return window.confirm('請問需要加糖嗎?');
    }
},'咖啡粉');
var Tea1 = Beverage1({
    addCondiments: function(){
        console.log('加檸檬');
    },
    isWantCondiments: function () {
        return window.confirm('請問需要加檸檬嗎?');
    }
},'茶葉');
var aCupOfCoffee = new Coffee1();
aCupOfCoffee.init();
//把水煮沸
//把咖啡粉倒進杯子
//把沸水倒進杯子
//加糖(點確定)
var aCupOfTea = new Tea1();
aCupOfTea.init();
//把水煮沸
//把茶葉倒進杯子
//把沸水倒進杯子
//加檸檬(點確定)

參考文獻: 《JavaScript模式》 《JavaScript設計模式與開發實踐》


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、 Date對象 定義:Date()可以返回系統當天的日期和時間; 註意:返回的是標註的時間格式 Sun Aug 07 22:50:03 2016 用法: 1.1 獲取時間對象 1.2 轉換成時間對象 1.3 Date.parse把日期格式的字元串轉換成毫秒形式,如果日期格式不正確,返回NaN 1 ...
  • github地址:https://github.com/lily1010/sass/tree/master/course02 用到的sass語法是: sass --watch test.scss:test.css --style compact --style expanded 如下圖: 1 類名嵌 ...
  • 1. == (o゜▽゜)o☆[BINGO!] Javascript有兩組相等運算符,一組是==和!=,另一組是 和!==。前者只比較值的相等,後者除了值以外,還比較類型是否相同。 請儘量不要使用前一組,永遠只使用 和!==。因為==預設會進行類型轉換,規則十分難記。如果你不相信的話,請回答下麵五個判 ...
  • 實際項目中li和裡邊的數值是動態生成的,需要控制它的寬度和顏色,效果如圖: 如果能實現顏色按數值規律變化就好了,目前顏色是固定到數組中的。 實例代碼如下: <!DOCTYPE html><html><head> <meta charset="utf-8"> <title></title> <styl ...
  • 今天在網上參觀到一個寫法,返回字元串個個字母的個數 得到:Object {a: 5, b: 2, c: 2} reduce我查到是es5新加了array函數,這裡不細說,有興趣自己查; 關鍵是‘=>’,是我第一次在js中見到;在網上查了查沒找到什麼資料,自己理解吧,希望有大神指正。 應該就是匿名函數 ...
  • 我們做項目的時候,經常遇到樣式層疊問題,被其他的樣式覆蓋,或者寫的權重不高沒效果,對權重沒有具體的分析,做了一個總結。 如下圖,css規則由選擇器和聲明塊組成,寫在選擇器後面大括弧里的就叫聲明。 一、樣式類型1、行間 2、內聯 3、外部 例子彙總html: style1.css style2.css ...
  • CSS背景在網頁設計中使用頻率非常高,然而對於這個開發人員很熟悉的CSS屬性,卻隱藏著許多不為初級開發人員熟知的細節,這篇文章嘗試扒開這層不為人知的面紗。 首先列舉一下CSS中關於元素背景的所有屬性並簡要描述了其作用,其中後面幾個屬性是在CSS3中新加入的。 下麵一一“理清”這些屬性 backgro ...
  • [1]contains [2]empty [3]parent [4]has [5]not [6]header [7]lang [8]root ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...