日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

深入淺出JavaScript前端中的設計模式

瀏覽:394日期:2022-06-09 15:56:16
目錄
  • 關于設計模式
  • 七種常見的設計模式
  • 單例模式
  • 工廠模式
  • 適配器模式
  • 裝飾器模式
  • 策略模式
  • 觀察者模式
  • 發(fā)布-訂閱模式

關于設計模式

軟件設計模式,又稱設計模式,是一套被反復使用、多數(shù)人知曉的、經(jīng)過分類編目的、代碼設計經(jīng)驗的總結。它描述了在軟件設計過程中的一些不斷重復發(fā)生的問題,以及該問題的解決方案。也就是說,它是解決待定問題的一系列套路,是前輩們的代碼設計經(jīng)驗的總結,具有一定的普遍性,可以重復使用。其目的是為了提高代碼的可重用性、代碼的可讀性和代碼的可靠性。

簡單地說就是一些通用的代碼編寫方式,它是經(jīng)過不斷考驗得出的一些總結道理,按照這樣的模式去編寫我們的代碼,沿著前人留下來的經(jīng)驗,我們就可以編寫出詩一般的代碼。

關于設計模式,我們需要知道五大基本原則(SOLID):

(1)單一職責原則:一個類,應該僅有一個引起它變化的原因,簡而言之,就是功能要單一。

(2)開放封閉原則:對擴展開放,對修改關閉。

(3)里氏替換原則:基類出現(xiàn)的地方,子類一定出現(xiàn)。兩個字總結-繼承。

(4)接口隔離原則:一個接口應該是一種角色,不該干的事情不敢,該干的都要干。簡而言之就是降低耦合、減低依賴。

(5)依賴翻轉原則:針對接口編程,依賴抽象而不依賴具體。所編寫的對象不應該跟具體的實例掛鉤,應該更偏抽象的概念。

更具體地描述設計模式的好處,有以下幾點:

①良好的封裝,不會讓內(nèi)部變量污染外部

②封裝好的代碼可以作為一個模塊給外部調用。外部無需了解細節(jié),只需按約定的規(guī)范調用。

③對擴展開放,對修改關閉,即開放關閉原則。外部不能修改內(nèi)部代碼,保證了內(nèi)部的正確性;又留出擴展接口,提高了靈活性。

像我們常用的各大框架,如React,Vue等都有不同設計模式的應用,Vue中使用了觀察者模式和發(fā)布-訂閱模式。

七種常見的設計模式

設計模式一共分為3大類23種,這里主要介紹常用的幾種。

①創(chuàng)建型模式:單例模式、工廠模式、建造者模式;

②結構型模式:適配器模式、裝飾器模式、代理模式;

③行為型模式:策略模式、觀察者模式、發(fā)布訂閱模式、職責鏈模式、中介者模式。

單例模式

單例模式:一個類只有一個實例,并提供一個訪問他的全局訪問點,即一個類只生成一個唯一的實例。

我們在一個類中聲明屬性instance,當調用函數(shù)getInstance時,我們判斷instance是否已經(jīng)存在實例,若存在則訪問該instance對象,若不存在則創(chuàng)建。

class Singleton {    let _instance = null;    static getInstance() {if (!Singleton._instance) {  Singleton.instance = new Singleton()}// 如果這個唯一的實例已經(jīng)存在,則直接返回return Singleton._instance    }}const s1 = Singleton.getInstance()const s2 = Singleton.getInstance()

Vuex就是一個典型的單例模式使用案例, store對象就是一個單例對象。

根據(jù)其功能代碼,我們可以看出單例模式的優(yōu)劣點都在哪里。

優(yōu)點: 節(jié)約資源,保證訪問的一致性。

缺點: 擴展性不友好,因為單例模式一般自行實例化,沒有接口。

工廠模式

這個模式我們就非常常用了,聲明一個class,然后根據(jù)傳進來的參數(shù)去生成對應的實例對象,就是所謂的工廠模式。每一個類就像一個已經(jīng)開設好的工廠,我們只需要告訴我們的需求,它就會生成我們想要的一個對象返回。

class Restaurant{    constructor(){this.menuData = {};    }    // 獲取菜品    getDish(dish){if(!this.menuData[menu]){    console.log("菜品不存在,獲取失敗");    return;}return this.menuData[menu];    },    // 添加菜品    addMenu(menu,description){if(this.menuData[menu]){    console.log("菜品已存在,請勿重復添加");    return;}this.menuData[menu] = menu;    }    // 移除菜品    removeMenu(menu){if(!this.menuData[menu]){    console.log("菜品不存在,移除失敗");    return;}delete this.menuData[menu];    },}class Dish{    constructor(name,description){this.name = name;this.description = description;    }    eat(){console.log(`I"m eating ${this.name},it"s ${`this.description);    }}

優(yōu)點:

  • 良好的封裝,訪問者無需了解創(chuàng)建過程,代碼結構清晰。
  • 擴展性良好,通過工廠方法隔離了用戶和創(chuàng)建流程,符合開閉原則。
  • 解耦了高層邏輯和底層產(chǎn)品類,符合最少知識原則,不需要的就不要去交流;

缺點:

缺點就是如果我們的類定義太過抽象復雜了,會出現(xiàn)閱讀性的問題。

適配器模式

這個模式也很好理解,相當于我們平時使用的一些產(chǎn)品,如投影儀之類的,如果我們的電線無法適配到我們的屏幕,我們就需要借助一個中間的適配器,讓兩者可以溝通起來。

interface bookDataType1 {  book_id: number;  status: number;  create: string;  update: string;}interface bookDataType2 {  id: number;  status: number;  createTime: number;  updateAt: string;}interface bookDataType3 {  book_id: number;  status: number;  createTime: number;  updateAt: number;}const getTimeStamp = function (str: string): number {  //.....轉化成時間戳  return timeStamp;};//適配器export const bookDataAdapter = {  adapterType1(list: bookDataType1[]) {    const bookDataList: bookData[] = list.map((item) => {      return {book_id: item.book_id,status: item.status,createAt: getTimeStamp(item.create),updateAt: getTimeStamp(item.update),      };    });    return bookDataList;  },  adapterType2(list: bookDataType2[]) {    const bookDataList: bookData[] = list.map((item) => {      return {book_id: item.id,status: item.status,createAt: item.createTime,updateAt: getTimeStamp(item.updateAt),      };    });    return bookDataList;  },  adapterType3(list: bookDataType3[]) {    const bookDataList: bookData[] = list.map((item) => {      return {book_id: item.book_id,status: item.status,createAt: item.createTime,updateAt: item.updateAt,      };    });    return bookDataList;  },};

優(yōu)點: 可以使原有邏輯得到更好的復用,有助于避免大規(guī)模改寫現(xiàn)有代碼,為了不改動原有的代碼而做出的一種妥協(xié);

缺點:會讓系統(tǒng)變得零亂,明明調用 A,卻被適配到了 B,如果濫用,那么對可閱讀性不太友好。簡而言之搞復雜了,所以通常建議不要出現(xiàn)以上這樣的格式問題,應該跟后端溝通好數(shù)據(jù)。

裝飾器模式

典型的大腸包小腸,當前使用的對象無法滿足我們的全部需求,于是乎我們建一個新的類,再把這個對象在類中進行擴展,再生成一個新的對象。

策略模式

這個是相當相當常用,而且很好用的一個設計模式,可以讓我們根據(jù)不同的選擇去實現(xiàn)對應的功能,省略了大量的if,else。

比如我們現(xiàn)在有一個需求判斷,比如我現(xiàn)在要根據(jù)別人給我的不同食材去制造料理,最暴力常規(guī)那就是if,else多寫幾個就解決了。但是這里如果我們用策略模式就可以用很清晰,很簡潔的代碼去解決這個問題。

if ( "food" == "蘋果") {      水煮()} else if ("food" == "胡蘿卜") {      炒了()} else if ("food" == "魚") {      清蒸()} else if ("food" == "豬肉") {      炸了()} else if ("food" == "牛肉") {      烤了()} else {      生吃()}// 用了策略模式,看起來舒服多了let wayObj = {    "蘋果": 水煮(),    "胡蘿卜": 炒了(),    "魚": 清蒸(),    "豬肉": 炸了(),    "牛肉": 烤了(),    "不知道": 生吃()}

觀察者模式

這個模式從名字就可以看出來它是干嘛的,觀察者重點就是觀察,有兩個對象,一個是觀察,一個是被觀察,被觀察發(fā)生了變化,那我們觀察的對象就可以知道這個變化。

觀察者模式有一個別名叫“發(fā)布-訂閱模式”,或者說是“訂閱-發(fā)布模式”,訂閱者和訂閱目標是聯(lián)系在一起的,當訂閱目標發(fā)生改變時,逐個通知訂閱者。我們可以用報紙期刊的訂閱來形象的說明,當你訂閱了一份報紙,每天都會有一份最新的報紙送到你手上,有多少人訂閱報紙,報社就會發(fā)多少份報紙,報社和訂報紙的客戶就是上面文章開頭所說的“一對多”的依賴關系。

// 觀察者模式 被觀察者Subject 觀察者Observer Subject變化 notify觀察者let observerIds = 0;// 被觀察者Subjectclass Subject {  constructor() {    this.observers = [];  }  // 添加觀察者  addObserver(observer) {    this.observers.push(observer);  }  // 移除觀察者  removeObserver(observer) {    this.observers = this.observers.filter((obs) => {      return obs.id !== observer.id;    });  }  // 通知notify觀察者  notify() {    this.observers.forEach((observer) => observer.update(this));  }}// 觀察者Observerclass Observer {  constructor() {    this.id = observerIds++;  }  update(subject) {    // 更新  }}

發(fā)布-訂閱模式

其實上面也說了,跟觀察者模式是有異曲同工之妙的,但是它可以是一個一對多的關系,而且它需要一個中間人。

class Event {  constructor() {    this.eventEmitter = {};  }  // 訂閱  on(type, fn) {    if (!this.eventEmitter[type]) {      this.eventEmitter[type] = [];    }    this.eventEmitter[type].push(fn);  }  // 取消訂閱  off(type, fn) {    if (!this.eventEmitter[type]) {      return;    }    this.eventEmitter[type] = this.eventEmitter[type].filter((event) => {      return event !== fn;    });  }  // 發(fā)布  emit(type) {    if (!this.eventEmitter[type]) {      return;    }    this.eventEmitter[type].forEach((event) => {      event();    });  }}

到此這篇關于深入淺出JavaScript前端中的設計模式的文章就介紹到這了,更多相關JS設計模式內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
六月丁香综合在线视频| 国产a久久精品一区二区三区| 98精品视频| 美女精品一区二区| 精品网站aaa| 国产成人精品亚洲线观看| 国产一区二区三区久久| 超级白嫩亚洲国产第一| 欧美sss在线视频| 今天的高清视频免费播放成人| 97人人精品| 色婷婷精品视频| 91久久久精品国产| 亚洲欧美日韩在线观看a三区| 国产视频一区免费看| 五月天激情综合网| 久久亚洲国产精品一区二区| 日本欧洲一区二区| 欧美一区=区三区| 国产精品免费99久久久| 成人高清一区| 亚洲激情中文| 日韩精品免费一区二区夜夜嗨| 国产欧美日韩精品一区二区三区| 免费在线欧美黄色| 999久久久国产精品| 亚洲电影在线| 亚洲精品乱码久久久久久蜜桃麻豆| 久久国产麻豆精品| 电影91久久久| 国产亚洲精品久久久久婷婷瑜伽| 亚洲三级视频| 国产激情久久| 在线视频观看日韩| 亚洲精选av| 另类小说一区二区三区| 亚洲天堂黄色| 91亚洲精品视频在线观看| 国产成人免费视频网站视频社区| 亚洲国产专区校园欧美| 日韩福利视频导航| 红杏一区二区三区| 中文一区在线| 欧美成人精品午夜一区二区| 久久久水蜜桃av免费网站| 亚洲日韩中文字幕一区| 国产成人a视频高清在线观看| 五月天久久久| 免费视频一区二区三区在线观看| 欧美日韩在线二区| 欧美日韩亚洲一区在线观看| 国产精品久久久久av电视剧| 亚洲无线观看| 欧美三区四区| 日本视频中文字幕一区二区三区| 中文一区一区三区高中清不卡免费| 欧美aa国产视频| 欧美国产视频| 午夜在线一区二区| 国产成人久久精品麻豆二区| 国产精品美女| 国产一区二区视频在线看| 先锋影音久久久| 高清av一区| 日韩视频一二区| 亚洲国产专区| 国内精品美女在线观看| 伊人久久亚洲| 国产一区日韩一区| 精品五月天堂| 久久国产视频网| 91久久黄色| 亚洲伊人av| 国产精品一区三区在线观看| 怡红院精品视频在线观看极品| 免费视频一区二区三区在线观看 | 日本电影久久久| 日本欧美不卡| 久久99精品久久久久久园产越南| 亚洲欧美网站在线观看| 亚洲午夜精品久久久久久app| 免费看久久久| 91亚洲精品在看在线观看高清| 一区二区自拍| 麻豆成全视频免费观看在线看| 午夜亚洲福利| 性一交一乱一区二区洋洋av| 电影天堂国产精品| 精品三级在线| 国产亚洲人成a在线v网站| 玖玖玖国产精品| 国产尤物精品| 日本免费一区二区三区四区| 麻豆国产欧美日韩综合精品二区| 色综合视频一区二区三区日韩| 好看的av在线不卡观看| 成人日韩在线| 国产欧美一区二区三区精品酒店| 国产精品久久| 国产日韩一区二区三免费高清| 先锋亚洲精品| 久久最新视频| 国产免费成人| 欧美网站在线| 欧美女激情福利| 亚洲成人一区| 99久久久久国产精品| 蜜桃视频在线网站| 国产美女高潮在线观看| 麻豆国产一区| 国产美女亚洲精品7777| 日韩激情中文字幕| 中文字幕av一区二区三区人| 亚洲综合国产| 男人天堂欧美日韩| 亚洲欧美日韩高清在线| 亚洲午夜一级| 91成人精品| 亚洲欧美视频| 免费成人在线观看| 亚洲精品乱码久久久久久蜜桃麻豆| 免费日韩精品中文字幕视频在线| 99视频一区| 蜜桃91丨九色丨蝌蚪91桃色| 久久av一区| 亚洲三级国产| 91精品丝袜国产高跟在线| 日韩一区二区三区在线看| 亚洲精品在线a| 日本成人在线不卡视频| 日本不卡的三区四区五区| 日韩三级视频| 欧美日韩夜夜| 国产一区丝袜| 日本精品不卡| 一区久久精品| 亚洲乱码一区| 国产精品日本一区二区不卡视频| 国产精品久久久久久妇女| 久久精品国产成人一区二区三区| 国内自拍视频一区二区三区| 天堂av在线| 欧美精品黄色| 婷婷五月色综合香五月| 亚洲乱码一区| 国产精品一区二区中文字幕| 美女国产一区二区三区| 日韩免费看片| 亚洲大全视频| 婷婷五月色综合香五月| 国产精品777777在线播放 | 国产精品2023| 精品国产乱码久久久久久樱花| 岛国av免费在线观看| 日本在线精品| 一本综合精品| 欧美日韩亚洲一区| 国产一区二区三区成人欧美日韩在线观看 | 国产欧美一区二区三区精品观看 | 国产精品免费大片| 日韩精品电影| 爽好久久久欧美精品| 91大神在线观看线路一区| 精品久久亚洲| 国产亚洲在线| 国产情侣一区| 欧美成人精品三级网站| 蜜臀av一区二区在线免费观看| 国产精品极品国产中出| 999国产精品永久免费视频app| 亚洲久久一区| 成人在线免费观看网站| 亚洲一区二区三区高清不卡| 91成人在线精品视频| 亚洲www啪成人一区二区| 蜜桃久久久久久| 精品国产美女a久久9999| 99视频精品免费观看| 另类综合日韩欧美亚洲| 欧美精品激情| 国产精品一国产精品k频道56| 亚洲a一区二区三区| 亚洲精品日本| 亚洲女同av| 色综合视频一区二区三区日韩| 福利一区二区三区视频在线观看| 亚洲一区欧美二区| 丁香婷婷久久| 日本中文字幕视频一区| 91精品国产91久久久久久黑人| 亚洲乱码视频| 成人啊v在线| 国产亚洲久久| 亚洲韩日在线| 麻豆久久久久久久| 欧美综合国产| 亚洲成人不卡| 欧美激情麻豆| 五月激激激综合网色播| 久久国产亚洲|