欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript設(shè)計(jì)模式策略模式案例分享

 更新時(shí)間:2022年06月23日 14:29:52   作者:??前端若水????  
這篇文章主要介紹了JavaScript設(shè)計(jì)模式策略模式案例分享,策略設(shè)計(jì)模式就是指一個問題匹配多個解決方法,不一定要用到哪一個,而且有可能隨時(shí)增加多個方案

前言

策略設(shè)計(jì)模式就是指一個問題匹配多個解決方法,不一定要用到哪一個,而且有可能隨時(shí)增加多個方案

比如我們?nèi)ベI書,書店都會搞一些優(yōu)惠活動,滿100減20,滿200減50,八折優(yōu)惠這些,但是優(yōu)惠活動源源不止這些,后期會陸續(xù)添加優(yōu)惠活動,比如雙11活動打七折,等到雙11活動過去之后打七折活動還需要取消

我們先不用策略設(shè)計(jì)模式進(jìn)行實(shí)現(xiàn)計(jì)算折扣后價(jià)格,我們聲明一個方法,里面接受倆個參數(shù),這倆個參數(shù)一個是價(jià)格一個是折扣種類,然后在方法里面使用if語句判斷折扣種類計(jì)算價(jià)格,如果沒有折扣就是原價(jià),最后把計(jì)算過的折扣價(jià)格返回出去

//price 價(jià)格 
//type 折扣種類
 function calcPrice(price, type) {
            if (type == '100_20') {
                price -= 20
            } else if (type == '200_50') {
                price -= 50
            }
            return price;

        }
        // 使用
        const bookPrice = calcPrice(300, '100_20')

這種方式如果是折扣活動比較少的情況下還行,但是每次添加新的折扣活動都需要去往方法里面添加折扣活動的if語句判斷以及記住新折扣種類的字段以免和之前的折扣活動名字重復(fù),對于折扣活動到期的情況還需要手動進(jìn)行刪除該if語句,長此以往代碼不僅冗余還很維護(hù)

使用策略設(shè)計(jì)模式實(shí)現(xiàn):

我們聲明一個閉包函數(shù),閉包函數(shù)中有一個折扣種類中心,里面有默認(rèn)的幾個折扣種類,還有一個計(jì)算折扣價(jià)格的方法,方法上我們又給他定義了倆個方法,一個是添加折扣種類方法,一個是刪除折扣種類方法,然后在把計(jì)算折扣方法暴露出去就可以了

//計(jì)算折扣價(jià)格閉包函數(shù)
        const calcPrice = (function() {
            // 折扣種類中心
            const sale = {
           //100-20折扣活動
                    '100_20': function(price) {
                        return price -= 20
                    },
                    //200-50折扣活動
                    '200_50': function(price) {
                        return price -= 50
                    },
                    //打八折折扣活動
                    '80%': function(price) {
                        return price *= 0.8
                    },
                }
     
               /** *
               * 計(jì)算折扣價(jià)格
               * price 價(jià)格 
               * type 折扣類型
               * **/
            function totalPrice(price, type) {
                // 判斷折扣種類里面是否擁有這個折扣類型,如果有就執(zhí)行,沒有就返回原價(jià)
                if (sale[type]) {
                    // 使用折扣函數(shù)
                    price = sale[type](price)
                }
                // 返回價(jià)格
                return price
            }
            /**
             * 
             *  添加折扣方法
             *  type  折扣類型
             * callback 折扣類型方法
             * **/
            totalPrice.add = function(type, callback) {
                    // 判斷折扣類型是否存在
                    if (sale[type]) return '折扣已存在'
                    //給折扣類型中心添加折扣價(jià)格方法
                    sale[type] = callback
                    return '折扣方法添加成功'
                }
                // 刪除折扣方法
                totalPrice.del(type){
                //通過delete關(guān)鍵字刪除折扣類型中心方法
                   delete   sale[type] 
                }
             // 被return出去的函數(shù),才是計(jì)算價(jià)格的本體
            return totalPrice
        })();
        //使用計(jì)算價(jià)格
        const bookPrice = calcPrice(240, '200_50');
       //添加打七折折扣類型方法
       calcPrice.add('70%',function(price) {return price *= 0.7 })
       //刪除打八折折扣類型方法
        calcPrice.add('80%')

策略設(shè)計(jì)模式擁有易于維護(hù),易于理解,易于擴(kuò)展的特點(diǎn)

到此這篇關(guān)于JavaScript設(shè)計(jì)模式策略模式案例分享的文章就介紹到這了,更多相關(guān)JavaScript 策略模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js利用div背景,做一個豎線的效果。

    js利用div背景,做一個豎線的效果。

    嘗試了好多種css屬性,總是無法達(dá)成目標(biāo)。主要就是height這個屬性,100%,對于ff似乎并不起什么作用,既然我將其父容器的高度也設(shè)置為100%,依然沒有效果。這樣的話,就無法顯示出平鋪的背景,想法也得不到實(shí)現(xiàn)。
    2008-11-11
  • JS獲取和修改元素樣式的實(shí)例代碼

    JS獲取和修改元素樣式的實(shí)例代碼

    下面小編就為大家?guī)硪黄狫S獲取和修改元素樣式的實(shí)例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • setTimeout函數(shù)的神奇使用

    setTimeout函數(shù)的神奇使用

    setTimeout函數(shù)是一個原生的javascript函數(shù)。setTimeout函數(shù)會在一個指定的延遲時(shí)間之后調(diào)用一個函數(shù)或執(zhí)行一段指定的代碼。它的應(yīng)用非常廣泛,例如我們希望用戶在瀏覽器某個頁面一段時(shí)間后彈出一個對話框,或者是鼠標(biāo)點(diǎn)擊某個元素后隔幾秒鐘在刪除這個元素。
    2017-02-02
  • Bootstrap輪播加上css3動畫,炫酷到底!

    Bootstrap輪播加上css3動畫,炫酷到底!

    這篇文章將展示如何在 Bootstrap輪播上添加有趣的動畫效果,同時(shí)確保這個js組件自由擴(kuò)展和快速上手,感興趣的小伙伴們可以參考一下
    2015-12-12
  • 封裝的dialog插件 基于bootstrap模態(tài)對話框的簡單擴(kuò)展

    封裝的dialog插件 基于bootstrap模態(tài)對話框的簡單擴(kuò)展

    這篇文章主要介紹了基于bootstrap模態(tài)對話框的簡單擴(kuò)展,bootstrap-mzDialog插件的封裝,感興趣的小伙伴們可以參考一下
    2016-08-08
  • vue雙向綁定簡要分析

    vue雙向綁定簡要分析

    這篇文章主要介紹了vue雙向綁定的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • JS保留小數(shù)點(diǎn)(四舍五入、四舍六入)實(shí)現(xiàn)思路及實(shí)例

    JS保留小數(shù)點(diǎn)(四舍五入、四舍六入)實(shí)現(xiàn)思路及實(shí)例

    保留兩位小數(shù):將浮點(diǎn)數(shù)四舍五入,取小數(shù)點(diǎn)后2位;如:2,會在2后面補(bǔ)上00.即2.00,感興趣的朋友看下具體的實(shí)現(xiàn)思路及代碼
    2013-04-04
  • js控住DOM實(shí)現(xiàn)發(fā)布微博效果

    js控住DOM實(shí)現(xiàn)發(fā)布微博效果

    這篇文章主要為大家詳細(xì)介紹了js控住DOM實(shí)現(xiàn)發(fā)布微博效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • 交叉觀察器?IntersectionObserver用法詳解

    交叉觀察器?IntersectionObserver用法詳解

    這篇文章主要為大家介紹了交叉觀察器?IntersectionObserver用法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • 微信小程序開發(fā)之獲取用戶信息的兩種方法

    微信小程序開發(fā)之獲取用戶信息的兩種方法

    小程序可以通過微信官方提供的登錄方法方便地獲取微信提供的用戶身份標(biāo)識,進(jìn)而開發(fā)者可以進(jìn)行下一步操作,下面這篇文章主要給大家介紹了關(guān)于微信小程序開發(fā)之獲取用戶信息的兩種方法,需要的朋友可以參考下
    2022-03-03

最新評論