摘要:也是一些架構(gòu)師常用的模式。寫出方法,需要子類自己定義穿衣服需要子類自定義洗臉?biāo)⒀雷宇愖远x方法出門準(zhǔn)備工作需要子類自定義出門穿阿迪吊絲的衣服整理文件,找工作恩,這個(gè)模板,差不多能滿足正常人的需求。
所謂的模板就是一個(gè)重用一萬次都不會覺得有問題的代碼。 在es6中,提出了一個(gè) "``"反引號的書寫方式--又叫做模板字符串.他最大的功能就是用來書寫模板html的.
通常在js中使用模板是
"There are " + basket.count + " " + "items in your basket, " + "" + basket.onSale + " are on sale!"
像這樣使用的
在ES6中引入了模板字符串的概念,只需要使用反引號進(jìn)行包裹就可以: 引入的變量可以使用${}進(jìn)行包裹上面可以修改為:
` //這里就是反引號,注意不是上引號,而是鍵盤esc下面那個(gè)鍵 There are ${basket.count} items //插入指定的變量 in your basket, ${basket.onSale} are on sale! `
上面的代碼就可以作為一串模板代碼出現(xiàn)。
同理,在js的設(shè)計(jì)模式中,也存在模板方法模式.
模板方法模式是一種基于類和繼承的模式。也是一些架構(gòu)師常用的模式。
看個(gè)栗子: 小明起床
首先,小明起床,喜歡穿NB系列衣服,然后洗臉?biāo)⒀?,整理書包,出門。(我這里列的是大部分人有的,如果遇見一些生活習(xí)慣不同的,那先將就下吧。:)
轉(zhuǎn)換為代碼:
var GetUp = function(){} GetUp.prototype.wear = function(){ console.log("穿NB系列的衣服"); } GetUp.prototype.brush = function(){ console.log("洗臉?biāo)⒀?); } GetUp.prototype.sortOut = function(){ console.log("整理書包"); } GetUp.prototype.out = function(){ console.log("出門"); } GetUp.prototype.init = function(){ this.wear(); this.brush(); this.sortOut(); this.out(); } var xiaoming = new GetUp(); xiaoming.init();
看上去,可以完美的表達(dá)小明的起床過程,但是我們是有情懷的人。我們想做的是,能不能抽象出一個(gè)大部分人都能用的起床模式. 有,我們可以想想。
我是一個(gè)窮逼,我家只能穿阿迪吊絲的衣服,
我現(xiàn)在正在找工作,我需要整理文件。
然后,洗臉?biāo)⒀肋@個(gè)習(xí)慣還是有的。
出門是必須的。
那么對比可以看出,只有兩個(gè)方法的內(nèi)容不一樣,只需要對這兩個(gè)方法進(jìn)行抽象. 相當(dāng)于寫一個(gè)抽象方法,然后讓子類自己重寫。
var GetUp = function(){} GetUp.prototype.wear = function(){ //寫出方法,需要子類自己定義 throw "穿衣服需要子類自定義"; } GetUp.prototype.brush = function(){ console.log("洗臉?biāo)⒀?); } GetUp.prototype.sortOut = function(){ //子類自定義方法 throw "出門準(zhǔn)備工作需要子類自定義"; } GetUp.prototype.out = function(){ console.log("出門"); } GetUp.prototype.init = function(){ this.wear(); this.brush(); this.sortOut(); this.out(); } var xiaoMing = new GetUp(); xiaoMing.wear = function(){ console.log("穿阿迪吊絲的衣服"); } xiaoMing.sortOut = function(){ console.log("整理文件,找工作"); } xiaoMing.init();
恩,這個(gè)模板,差不多能滿足正常人的需求。 但是,世界只有相對性,而沒有絕對性,某些有怪癖,比如,早上不洗臉?biāo)⒀?這種情況也是存在的。(我小時(shí)候,為了逃避刷牙,經(jīng)常起得比我媽還早,就跑去上課). md, 怪不得我那時(shí)候同座都嫌棄我,哎,也沒有找到小時(shí)候的知己?,F(xiàn)在腸子都悔青了。
回正題。所以,要滿足這類人的需求,我們要用到一個(gè)叫做鉤子方法。其實(shí)就是一個(gè)flag.用來代表你是不是比較特殊的人。
var GetUp = function(){} GetUp.prototype.wear = function(){ //寫出方法,需要子類自己定義 throw "穿衣服需要子類自定義"; } GetUp.prototype.brush = function(){ console.log("洗臉?biāo)⒀?); } GetUp.prototype.sortOut = function(){ //子類自定義方法 throw "出門準(zhǔn)備工作需要子類自定義"; } GetUp.prototype.out = function(){ console.log("出門"); } GetUp.prototype.needBrush = function(){ //是否需要刷牙,默認(rèn)為需要 return true; } GetUp.prototype.init = function(){ this.wear(); if(this.needBrush())this.brush(); this.sortOut(); this.out(); } var xiaoMing = new GetUp(); xiaoMing.wear = function(){ console.log("穿阿迪吊絲的衣服"); } xiaoMing.sortOut = function(){ console.log("整理文件,找工作"); } xiaoMing.needBrush = function(){return false;} xiaoMing.init();
上面自定義的 "needBrush" 方法就是一個(gè)鉤子方法,用來表明,這個(gè)人是不是特立獨(dú)行的人。
其實(shí),我們拋開鉤子的寫法,了解下他的本質(zhì),我們可以發(fā)現(xiàn),一個(gè)鉤子的添加,是給你抽象類的重用性大大加分的一項(xiàng),將變化的一部分,給分離出來,更大程度的讓代碼得到重用.
但是,在js中寫類,有點(diǎn)太過牽強(qiáng)。要知道js中,函數(shù),對象才是一等公民.我們可以使用高階函數(shù)重構(gòu)一個(gè)例子.
var GetUp = function(person){ var wear = person.wear || function(){ throw "穿衣服需要子類自定義"; } var brush = function(){ console.log("洗臉?biāo)⒀?); } var sortOut = person.sortOut || function(){ throw "出門準(zhǔn)備工作需要子類自定義"; } var needBrush = person.needBrush || function(){ return true; } var out = function(){ console.log("出門"); } var init = function(){ wear(); if(needBrush()) brush(); sortOut(); out(); } return function(){ init(); } } var jimmy = { wear(){ console.log("穿鳥不拉屎的衣服"); }, sortOut(){ console.log("整理書包"); } } var _jimmy = GetUp(jimmy); _jimmy();
但是為了統(tǒng)一,可以將init方法返回.
var GetUp = function(person){ //... return { init } } var _jimmy = GetUp(jimmy); _jimmy.init();
這樣寫,更具有代表性,讓人能夠一眼看出來表示的意思.
模板方法的應(yīng)用模板方法的應(yīng)用,其實(shí)往大的用,是給架構(gòu)師來使用。比如他設(shè)計(jì)一個(gè)模板,然后交給底層程序員去實(shí)現(xiàn)。相當(dāng)于,一個(gè)產(chǎn)經(jīng)提一個(gè)需求,然后交給你來實(shí)現(xiàn)具體的內(nèi)容(這兩者的區(qū)別就是,一個(gè)可以忽悠,另一個(gè)不能忽悠).
往小的用,那就不叫模板了,就是普通的策略者模式了。
說了這么多,其實(shí),廢話+n. 模板方法在我們這個(gè)level 其實(shí)用的還是比較少了。當(dāng)然也不排除,你對這個(gè)模板方法有著SM的愛好,天天套它。所以,還是一句話,不要為了模式而模式。看自己心情使用吧.
ending~
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91615.html
摘要:設(shè)計(jì)模式的分類經(jīng)典應(yīng)用框架中常見的設(shè)計(jì)模式分為三類創(chuàng)建型模式對類的實(shí)例化過程的抽象。對象的結(jié)構(gòu)模式是動(dòng)態(tài)的。對象的行為模式則使用對象的聚合來分配行為。設(shè)計(jì)模式是個(gè)好東西,以后肯定還要進(jìn)一步的學(xué)習(xí),并且在項(xiàng)目中多實(shí)踐,提升自己的設(shè)計(jì)能力。 什么是設(shè)計(jì)模式? Christopher Alexander?說過:每一個(gè)模式描述了一個(gè)在我們周圍不斷重復(fù)發(fā)生的問題,以及該問題的解決方案的核心。這樣...
摘要:畢竟,架構(gòu)師不參與寫代碼的工作。例如,通常架構(gòu)師需要針對可能發(fā)生的每種情況進(jìn)行規(guī)劃。這種架構(gòu)師需要信任開發(fā)團(tuán)隊(duì)來編寫代碼。 showImg(https://segmentfault.com/img/bVblaqV?w=900&h=383); Talk is cheap, show me the code!但是在互聯(lián)網(wǎng)企業(yè)中,身處技術(shù)要職的架構(gòu)師到底需不需要寫代碼? showImg(ht...
摘要:架構(gòu)師寫代碼寫代碼的架構(gòu)師應(yīng)在第一時(shí)間發(fā)現(xiàn)代碼問題,及時(shí)反饋。精通高并發(fā)卻不知道高并發(fā)的瓶頸在哪精通架構(gòu)設(shè)計(jì)卻不能保證系統(tǒng)高可用架構(gòu)師最重要的工作就是實(shí)踐與大牛之間的距離要客觀的評價(jià)自己的能力。 1. 體系化的學(xué)習(xí) 每天的時(shí)間使有限的,而接觸的信息是無窮無盡的。在熟悉了工作之后,最重要的事情就是如何提高學(xué)習(xí)的效率,最好的辦法是: 體系化的學(xué)習(xí) 擁有了體系化結(jié)構(gòu)知識之后,再去了解別人的觀...
摘要:作為一名前端架構(gòu)師,你的工作是不斷地探索和評估新的技術(shù)平臺方法和框架。世界上沒有一刀切式的解決方案,而前端架構(gòu)師的使命正是將項(xiàng)目的需求與前端開發(fā)的實(shí)際情況相結(jié)合。 做前端工作一段時(shí)間了,也寫了不少的項(xiàng)目。但是突然好像快要失去了興趣。美工、后臺、項(xiàng)目經(jīng)理、測試等人員多層夾擊。美工說就這么設(shè)計(jì),你就得完全按著來。后臺說這個(gè)需求做不了,得那樣做,于是已經(jīng)做好的頁面推倒重來。測試說,這樣做更符...
摘要:從根本上講,架構(gòu)師是一個(gè)技術(shù)領(lǐng)導(dǎo)者的角色,這就是最大的區(qū)別。對于這個(gè)問題來說,沒錯(cuò),有一些相關(guān)主題沒有出現(xiàn)在這本書中,這些主題可以構(gòu)成一本與程序員必讀之軟件架構(gòu)相互補(bǔ)的書。我從軟件架構(gòu)的視角特別能注意到這件事。 非商業(yè)轉(zhuǎn)載請注明作譯者、出處,并保留本文的原始鏈接:http://www.ituring.com.cn/article/178034 Simon Brown 是全球知...
閱讀 2760·2021-11-16 11:45
閱讀 1668·2021-09-26 10:19
閱讀 2062·2021-09-13 10:28
閱讀 2822·2021-09-08 10:46
閱讀 1547·2021-09-07 10:13
閱讀 1544·2019-08-30 13:50
閱讀 1383·2019-08-30 11:17
閱讀 1463·2019-08-29 13:18