朋友圈

17332948818

全國(guó)統(tǒng)一學(xué)習(xí)專線 9:00-21:00

位置:程序開(kāi)發(fā)培訓(xùn)資訊 > 前端開(kāi)發(fā)培訓(xùn)資訊 > 北京web*端常見(jiàn)的設(shè)計(jì)模式,*端領(lǐng)域中的設(shè)計(jì)模式(二)

北京web*端常見(jiàn)的設(shè)計(jì)模式,*端領(lǐng)域中的設(shè)計(jì)模式(二)

日期:2022-07-13 15:22:19     瀏覽:315    來(lái)源:北京培訓(xùn)教育
核心提示:現(xiàn)在web前端也是一個(gè)非常熱門的行業(yè),想要學(xué)習(xí)web前端開(kāi)發(fā)的同學(xué)請(qǐng)看這里北京web前端常見(jiàn)的設(shè)計(jì)模式 ,通過(guò)對(duì)前端領(lǐng)域中的設(shè)計(jì)模式(二)?? 的了解,希望以上信息可以幫助到您1.前端領(lǐng)域中的設(shè)計(jì)模式(二)繼續(xù)我們上

現(xiàn)在web前端也是一個(gè)非常熱門的行業(yè),想要學(xué)習(xí)web前端開(kāi)發(fā)的同學(xué)請(qǐng)看這里北京web前端常見(jiàn)的設(shè)計(jì)模式 ,通過(guò)對(duì)前端領(lǐng)域中的設(shè)計(jì)模式(二)?? 的了解,希望以上信息可以幫助到您

1.前端領(lǐng)域中的設(shè)計(jì)模式(二)

繼續(xù)我們上文設(shè)計(jì)模式前端相關(guān)實(shí)現(xiàn)3.2、結(jié)構(gòu)型設(shè)計(jì)設(shè)計(jì)模式3.2.1、裝飾器模式裝飾器模式: 允許向一個(gè)現(xiàn)有的對(duì)象添加新的功能,同時(shí)又不改變其結(jié)構(gòu),為現(xiàn)有的對(duì)象(類)的一個(gè)包裝。主要基本原則:開(kāi)放封閉原則和單一職責(zé)模式模式介紹:在了解模式之前,我們先來(lái)聊一下前端中的高階函數(shù)。高階函數(shù)就是一個(gè)函數(shù)A可以接收函數(shù)B為參數(shù)。如: 常見(jiàn)應(yīng)用場(chǎng)景:三大框架中的高高階組件設(shè)計(jì)、ES7以后的裝飾器、vue mixins(vue 替代)、core-包等3.2.2、適配器模式適配器模式:兩個(gè)不兼容的接口之間的橋梁,它涉及一個(gè)單一的類,該類負(fù)責(zé)加入獨(dú)立的或不兼容的接口功能。簡(jiǎn)單理解: 接口(方法)轉(zhuǎn)換器。舉例說(shuō)明: 美國(guó)電器 110V,在*使用美國(guó)電器需要220V 的轉(zhuǎn)換器。主要基本原則:開(kāi)放封閉原則模式介紹: 該種設(shè)計(jì)模式提高了類的透明度、靈活性、復(fù)用度等,但是在大型項(xiàng)目開(kāi)發(fā)中,不易過(guò)多的使用適配器原則,會(huì)使項(xiàng)目錯(cuò)綜復(fù)雜,不易整體把握控制。前端中實(shí)際場(chǎng)景實(shí)現(xiàn):常見(jiàn)應(yīng)用場(chǎng)景:babel實(shí)現(xiàn)思想,npm/瀏覽器兼容等3.2.3、代理模式代理模式: 一個(gè)類代表另外一個(gè)類的功能,創(chuàng)建一個(gè)具有現(xiàn)有對(duì)象的對(duì)象,為外界提供訪問(wèn)接口。實(shí)際理解:如windows的快捷打開(kāi)方式。主要基本原則:開(kāi)放封閉原則、里氏替換原則模式介紹:該種模式就是為對(duì)象提供一個(gè)代理,控制對(duì)這個(gè)對(duì)象的訪問(wèn),在開(kāi)發(fā)中我們經(jīng)常遇到的代理可分為四種類型: 事件代理,虛擬代理、緩存代理和保護(hù)代理。事件代理:前端中應(yīng)該大家都很熟悉事件代理和事件委托。前端中,通過(guò)事件冒泡,制定一個(gè)時(shí)間處理程序,就可以管理某一類型的所有事件,有效的提升性能與操作。瀏覽器端的實(shí)現(xiàn)如: 虛擬代理:圖片預(yù)加載功能,先給 img 標(biāo)簽展示一個(gè)占位圖,然后創(chuàng)建一個(gè) Image 實(shí)例,讓這個(gè)實(shí)例的 src 指向真實(shí)的目標(biāo)圖片地址,當(dāng)其真實(shí)圖片加載完成之后,再將 DOM 上的 img 標(biāo)簽的 src 屬性指向真實(shí)圖片地址。簡(jiǎn)單實(shí)現(xiàn):緩存代理:一般使用在計(jì)算量較大的場(chǎng)景中,如去重優(yōu)化,計(jì)算緩存,實(shí)現(xiàn)如下:保護(hù)代理:也可以稱為代理拒絕,保護(hù)代理用于控制不同權(quán)限的對(duì)象對(duì)目標(biāo)對(duì)象的訪問(wèn),在js中場(chǎng)景不算多,大家知道起原理便可。3.2.4、橋接模式橋接模式:抽象化和實(shí)現(xiàn)話解耦,使得二者可以獨(dú)立變化,前端簡(jiǎn)單理解,函數(shù)的封裝,提升代碼的可維護(hù)性。在多維變化的編程中比較實(shí)用。舉一個(gè)簡(jiǎn)單的例子: N個(gè)操作系統(tǒng) 、M個(gè)電腦。主要基本原則:開(kāi)放封閉原則模式介紹:分離接口和實(shí)現(xiàn)部分,將抽象和實(shí)現(xiàn)充分解耦,產(chǎn)生更好的結(jié)構(gòu)話系統(tǒng),提高了系統(tǒng)的可擴(kuò)展性,對(duì)用戶隱藏了實(shí)現(xiàn)細(xì)節(jié)。簡(jiǎn)單實(shí)現(xiàn):使用場(chǎng)景:前端各大框架和npm包中都有或多或少的使用場(chǎng)景,大家可自行尋找學(xué)習(xí)。3.2.5、外觀模式外觀模式:隱藏系統(tǒng)的復(fù)雜性,向使用方提供一個(gè)可以訪問(wèn)系統(tǒng)的接口,它涉及到一個(gè)單一的類,該類提供了客戶端請(qǐng)求的簡(jiǎn)化方法和對(duì)現(xiàn)有系統(tǒng)類方法的委托調(diào)用。主要涉及模式:開(kāi)放封閉原則、單一匹配原則模式介紹:該模式對(duì)出口進(jìn)行了統(tǒng)一封裝,提高了系統(tǒng)的安全性和統(tǒng)一性。簡(jiǎn)單實(shí)現(xiàn)通過(guò)調(diào)用stopEvent簡(jiǎn)化了對(duì)冒泡事件和默認(rèn)事件的調(diào)用。統(tǒng)一了調(diào)用接口。使用場(chǎng)景:不用同步得到結(jié)果的編程思路, 如webpack打包思想等。3.2.6、組合模式組合模式: 部分整體模式,把相識(shí)的對(duì)象當(dāng)做一個(gè)單一的對(duì)象,與橋接模式區(qū)別在于,組合模式是一個(gè)樹(shù)形結(jié)構(gòu)為基準(zhǔn)的設(shè)計(jì)模式。主要設(shè)計(jì)原則:接口封閉開(kāi)放原則模式介紹:該種設(shè)計(jì)模式具有高層模塊調(diào)用簡(jiǎn)單、底層模塊自由添加的特點(diǎn),不過(guò)從設(shè)計(jì)結(jié)構(gòu)來(lái)說(shuō),這種樹(shù)形結(jié)構(gòu)設(shè)計(jì)違反了依賴反轉(zhuǎn)原則。具體實(shí)現(xiàn):常見(jiàn)場(chǎng)景: 具有樹(shù)形結(jié)構(gòu)的業(yè)務(wù)場(chǎng)景。3.2.7、享元模式享元模式:減少創(chuàng)建對(duì)象的數(shù)量,減少對(duì)內(nèi)存的消耗和提升性能,屬于優(yōu)化編程的設(shè)計(jì)模式。模式介紹:該模式運(yùn)用共享技術(shù)來(lái)有效支持大量細(xì)粒度的對(duì)象,系統(tǒng)中如果創(chuàng)建了大量類似的對(duì)象,,占用了大量的內(nèi)容,思考享元模式優(yōu)化方案就非常有必要了。下面我們思考一個(gè)場(chǎng)景:100套女裝、100套男裝,需要尋找模特來(lái)試妝,怎樣創(chuàng)建最少的model。簡(jiǎn)單設(shè)計(jì)思想:該模式核心為找到多個(gè)對(duì)象的共性問(wèn)題,及多個(gè)類似對(duì)象的共同點(diǎn),具體場(chǎng)景具體分析。該模式的設(shè)計(jì)思路與對(duì)象池設(shè)計(jì)類似,也可使用對(duì)象池優(yōu)化具體可參考工廠模式,設(shè)計(jì)一個(gè)對(duì)象池工廠。下一篇:前端領(lǐng)域中的設(shè)計(jì)模式(三)

看了以上有關(guān)前端領(lǐng)域中的設(shè)計(jì)模式(二)??的講解,如果還有什么疑問(wèn)可以直接來(lái)電咨詢

學(xué)員評(píng)價(jià)ASK list

  • 謝**評(píng)價(jià):老師講的非常棒,通俗易懂,難度適宜。舉的例子也很好理解。課的時(shí)間不長(zhǎng),只有四天,但是學(xué)到的東西真的很多。 老師也是非常負(fù)責(zé),原定的一小時(shí)課程,經(jīng)常講一個(gè)半小時(shí)以上,我們說(shuō)的\"大潘老師習(xí)慣性拖堂\"。真的非常感謝大潘老師和各位助教。
    手機(jī)號(hào)碼: 136****2592   評(píng)價(jià)時(shí)間: 2024-10-02
  • 未**評(píng)價(jià):任課老師上課講的非常細(xì)同學(xué)們聽(tīng)的認(rèn)真,學(xué)習(xí)氛圍很好。班主任認(rèn)真負(fù)責(zé)對(duì)每一位同學(xué)都觀察的十分仔細(xì),項(xiàng)目經(jīng)理老師對(duì)同學(xué)耐心解答難題。
    手機(jī)號(hào)碼: 138****8843   評(píng)價(jià)時(shí)間: 2024-10-02
  • 女**評(píng)價(jià):通過(guò)這幾天的系統(tǒng)學(xué)習(xí),使我掌握了一些專業(yè)的理論和實(shí)際操作知識(shí),讓我這個(gè)小白也對(duì)PYTHON語(yǔ)言編程課程產(chǎn)生了濃厚的興趣。并且,老師的專業(yè)水平很高,講課時(shí)深入淺出,傾囊相授,風(fēng)趣幽默,通俗易懂,答疑時(shí)耐心細(xì)致,知無(wú)不答,課后輔導(dǎo)不厭其煩,直到完全理解。通過(guò)這幾天的學(xué)習(xí),使我受益匪淺,在此感謝各位老師,希望以后還能有機(jī)會(huì)跟你們學(xué)習(xí)! 祝各位老師工作順利,身體健康!!!
    手機(jī)號(hào)碼: 181****8778   評(píng)價(jià)時(shí)間: 2024-10-02
  • 楊**評(píng)價(jià):知識(shí)點(diǎn)很好,很實(shí)用,每一節(jié)都有很大的收獲,非常的實(shí)用 而且老師講的也非常細(xì)致。
    手機(jī)號(hào)碼: 147****5484   評(píng)價(jià)時(shí)間: 2024-10-02
  • 未**評(píng)價(jià):老師講課全是干貨,還幫助我解決了很多工作中遇到的問(wèn)題,特別是課下還那么負(fù)責(zé)的進(jìn)行指點(diǎn)!老師確這樣在幫助我們學(xué)習(xí),太負(fù)責(zé)了!強(qiáng)烈建議大家來(lái)學(xué)習(xí),比別的機(jī)構(gòu)整天吹牛賣課 強(qiáng)的不是一點(diǎn)兒半點(diǎn)!
    手機(jī)號(hào)碼: 182****4873   評(píng)價(jià)時(shí)間: 2024-10-02
  • 范**評(píng)價(jià):1、很高興在短短四天,約八個(gè)小時(shí)的時(shí)間就完成了對(duì)python的入門學(xué)習(xí)。 2、老師授課很專業(yè),對(duì)專業(yè)理解也很強(qiáng)。 3、課堂的實(shí)時(shí)答疑很喜歡,有了現(xiàn)場(chǎng)教學(xué)的感覺(jué)。比枯燥的看錄播視頻來(lái)的更有情景感,帶入感。
    手機(jī)號(hào)碼: 147****6814   評(píng)價(jià)時(shí)間: 2024-10-02
  • 黃**評(píng)價(jià):寬敞明亮的教室,親切的老師、完整的課程、友善的同學(xué)(當(dāng)然在不認(rèn)識(shí)的情況下),都給我留下了深刻的印象。
    手機(jī)號(hào)碼: 130****6100   評(píng)價(jià)時(shí)間: 2024-10-02

本文由 北京培訓(xùn)教育 整理發(fā)布。更多培訓(xùn)課程,學(xué)習(xí)資訊,課程優(yōu)惠,課程開(kāi)班,學(xué)校地址等學(xué)校信息,可以留下你的聯(lián)系方式,讓課程老師跟你詳細(xì)解答:
咨詢電話:17332948818

如果本頁(yè)不是您要找的課程,您也可以百度查找一下: