JS設(shè)計(jì)原則 —— 單一職責(zé)原則

最近看了同事的代碼,感覺甚是優(yōu)雅病毡,再看看自己的濒翻,不禁自慚形穢,為了提高代碼的可擴(kuò)展性和可維護(hù)性等啦膜,是時(shí)候好好學(xué)習(xí)一下設(shè)計(jì)模式了有送。在學(xué)習(xí)設(shè)計(jì)模式之前,需要先看一下設(shè)計(jì)原則僧家,因?yàn)樵O(shè)計(jì)原則是核心思想雀摘。就好比練劍,設(shè)計(jì)原則是心訣要領(lǐng)啸臀,設(shè)計(jì)模式是招式届宠。

我們常說的SOLID原則,是包括單一職責(zé)原則乘粒、開閉原則、里式替換原則伤塌、接口隔離原則和依賴反轉(zhuǎn)原則這五個(gè)灯萍,與五個(gè)英文字母一一對(duì)應(yīng)。 今天每聪,就先來看一下單一職責(zé)原則旦棉。

什么是單一職責(zé)原則呢齿风?

英文:Single Responsibility Principle,縮寫SRP绑洛。英文描述:A class or module should have a single reponsibility.(一個(gè)類或模塊只負(fù)責(zé)完成一個(gè)功能)

這個(gè)定義很好理解救斑,比如我們開發(fā)的時(shí)候要實(shí)現(xiàn)一個(gè)filter組件,不僅實(shí)現(xiàn)了搜索的功能真屯,還把搜索之后的行為定義了出來脸候,例如把搜索結(jié)果作為參數(shù)發(fā)送請(qǐng)求。搜索和發(fā)送請(qǐng)求是兩個(gè)不同的功能绑蔫,再說搜索之后不一定是發(fā)送請(qǐng)求运沦,還可能是其他的行為,這就影響了組件的復(fù)用性配深,違反了單一職責(zé)原則携添。

所以對(duì)于類或模塊或者函數(shù)等,不要設(shè)計(jì)的大而全篓叶,盡量粒度小烈掠、功能單一,只包含一個(gè)職責(zé)缸托。如果包含多個(gè)職責(zé)左敌,在需求變更的過程中,就有可能因?yàn)樾薷钠渲幸粋€(gè)職責(zé)而引起其他職責(zé)出現(xiàn)bug嗦董。

如何看類或方法是否滿足單一職責(zé)原則呢母谎?

單一職責(zé)原則理解起來很簡單,我們都知道啥意思京革,但在具體應(yīng)用中還是有些難度的奇唤。不同的應(yīng)用場景、需求階段匹摇、業(yè)務(wù)層面咬扇,對(duì)同一個(gè)類的職責(zé)是否單一,可能會(huì)有不同的判定結(jié)果廊勃。

下面通過一個(gè)例子讓我們一起來學(xué)習(xí)一下懈贺。就拿疫情期間學(xué)生上網(wǎng)課來說吧,StudentInfo類大致會(huì)包含以下字段:

class StudentInfo {
  private name: string; // 姓名
  private age: number; // 年齡
  private class: string; // 班級(jí)
  private date: string; // 上課日期
  private onlineStartTime: string; // 網(wǎng)課開始時(shí)間
  private onlineEndTime: string; // 網(wǎng)課結(jié)束時(shí)間
  private province; // 省
  private city; // 市
  private region; // 地區(qū)
  private detailedAddress;  // 詳細(xì)地址
}

上面的這些字段能否都?xì)w屬于StudentInfo類呢坡垫?它符不符合單一職責(zé)原則呢梭灿?如果初始這個(gè)系統(tǒng)很簡單,所有的信息都只是用來展示而已冰悠,那都放到一起也沒有問題堡妒,因?yàn)樗鼈円泊_實(shí)都是學(xué)生的信息。后來有了新的需求溉卓,老師想看一看各個(gè)班級(jí)學(xué)生的網(wǎng)課情況皮迟,由于要對(duì)網(wǎng)課相關(guān)的信息做更多的處理搬泥,就可以把date、onlineStartTime伏尼、onlineEndTime字段拆分出來忿檩,獨(dú)立成一個(gè)類。經(jīng)過對(duì)網(wǎng)課情況的分析爆阶,發(fā)現(xiàn)有些學(xué)生經(jīng)常網(wǎng)課遲到燥透,那是不是某些地區(qū)網(wǎng)絡(luò)不好等情況影響的啊,這就需要地址信息做更多的分析操作扰她,也就可以把地址信息單獨(dú)拆分出來兽掰。

所以,在不同的需求階段或不同的業(yè)務(wù)背景應(yīng)用場景下徒役,對(duì)一個(gè)類是否職責(zé)單一的判定也是不同的孽尽。我們可以根據(jù)對(duì)業(yè)務(wù)的理解程度,預(yù)測之后可能會(huì)有哪些功能忧勿,來設(shè)計(jì)職責(zé)單一的類或模塊杉女。但很多時(shí)候我們無法預(yù)測之后的需求走向,這時(shí)可以先寫粗粒度的類鸳吸,之后根據(jù)需求變更再不斷重構(gòu)熏挎,畢竟重構(gòu)也是開發(fā)的一部分,可以讓代碼保持可讀性晌砾、可維護(hù)性坎拐、可擴(kuò)展性等。

現(xiàn)在我們知道判斷類是否職責(zé)單一是一個(gè)很靠感覺的東西养匈,不像算法題有固定的解法哼勇,這也是它在實(shí)施的過程中比較困難的地方。我在《設(shè)計(jì)模式之美》專欄中看到了王爭老師給出的一些判斷指標(biāo)很具有指導(dǎo)意義呕乎,出現(xiàn)下面的情況就可能說明類的設(shè)計(jì)不滿足單一職責(zé)原則:

  • 類中的代碼行數(shù)积担、函數(shù)或?qū)傩赃^多,會(huì)影響代碼的可讀性和可維護(hù)性
  • 類依賴的其他類過多猬仁,或依賴類的其他類過多帝璧,不符合高內(nèi)聚、低耦合的思想
  • 私有方法過多湿刽,就要考慮能否將私有方法獨(dú)立到新的類中的烁,設(shè)置為public,供更多的類使用诈闺,提高代碼復(fù)用性撮躁。
  • 比較難給類起一個(gè)合適的名字,很難用一個(gè)業(yè)務(wù)名詞概括买雾,或只能用籠統(tǒng)的詞語來命名把曼,就說明類的職責(zé)可能不夠清晰
  • 類中大量的方法都是集中操作類的某幾個(gè)屬性,就可以考慮將這幾個(gè)屬性和對(duì)應(yīng)的方法拆分出來漓穿。

為了滿足單一職責(zé)原則嗤军,是不是要把方法或類設(shè)計(jì)的越單一越好呢?

大家都聽說過“過猶不及”這個(gè)詞晃危,什么事都得有個(gè)度叙赚,如果為了追求單一職責(zé)原則而過度拆分,也會(huì)影響代碼的可讀性和可維護(hù)性僚饭。

不管使用什么設(shè)計(jì)原則和模式震叮,提高代碼的可讀性、可維護(hù)性鳍鸵、可擴(kuò)展性苇瓣、復(fù)用性,使代碼高內(nèi)聚偿乖、低耦合才是目的击罪。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市贪薪,隨后出現(xiàn)的幾起案子媳禁,更是在濱河造成了極大的恐慌,老刑警劉巖画切,帶你破解...
    沈念sama閱讀 212,454評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件竣稽,死亡現(xiàn)場離奇詭異,居然都是意外死亡霍弹,警方通過查閱死者的電腦和手機(jī)毫别,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來庞萍,“玉大人拧烦,你說我怎么就攤上這事《奂疲” “怎么了恋博?”我有些...
    開封第一講書人閱讀 157,921評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長私恬。 經(jīng)常有香客問我债沮,道長,這世上最難降的妖魔是什么本鸣? 我笑而不...
    開封第一講書人閱讀 56,648評(píng)論 1 284
  • 正文 為了忘掉前任疫衩,我火速辦了婚禮,結(jié)果婚禮上荣德,老公的妹妹穿的比我還像新娘闷煤。我一直安慰自己童芹,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評(píng)論 6 386
  • 文/花漫 我一把揭開白布鲤拿。 她就那樣靜靜地躺著假褪,像睡著了一般。 火紅的嫁衣襯著肌膚如雪近顷。 梳的紋絲不亂的頭發(fā)上生音,一...
    開封第一講書人閱讀 49,950評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音窒升,去河邊找鬼缀遍。 笑死,一個(gè)胖子當(dāng)著我的面吹牛饱须,可吹牛的內(nèi)容都是我干的域醇。 我是一名探鬼主播,決...
    沈念sama閱讀 39,090評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼冤寿,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼歹苦!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起督怜,我...
    開封第一講書人閱讀 37,817評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤殴瘦,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后号杠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蚪腋,經(jīng)...
    沈念sama閱讀 44,275評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評(píng)論 2 327
  • 正文 我和宋清朗相戀三年姨蟋,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了屉凯。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,724評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡眼溶,死狀恐怖悠砚,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情堂飞,我是刑警寧澤灌旧,帶...
    沈念sama閱讀 34,409評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站绰筛,受9級(jí)特大地震影響枢泰,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜铝噩,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評(píng)論 3 316
  • 文/蒙蒙 一衡蚂、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦毛甲、人聲如沸年叮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽谋右。三九已至,卻和暖如春补箍,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背啸蜜。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評(píng)論 1 266
  • 我被黑心中介騙來泰國打工坑雅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人衬横。 一個(gè)月前我還...
    沈念sama閱讀 46,503評(píng)論 2 361
  • 正文 我出身青樓裹粤,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蜂林。 傳聞我的和親對(duì)象是個(gè)殘疾皇子遥诉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容