<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        vue觀察模式淺析

        來源:懂視網 責編:小采 時間:2020-11-27 22:07:03
        文檔

        vue觀察模式淺析

        vue觀察模式淺析:觀察者模式 首先話題下來,我們得反問一下自己,什么是觀察者模式? 概念 觀察者模式(Observer):通常又被稱作為發布-訂閱者模式。它定義了一種一對多的依賴關系,即當一個對象的狀態發生改變的時候,所有依賴于它的對象都會得到通知并自動更新,解決了主
        推薦度:
        導讀vue觀察模式淺析:觀察者模式 首先話題下來,我們得反問一下自己,什么是觀察者模式? 概念 觀察者模式(Observer):通常又被稱作為發布-訂閱者模式。它定義了一種一對多的依賴關系,即當一個對象的狀態發生改變的時候,所有依賴于它的對象都會得到通知并自動更新,解決了主

        觀察者模式

        首先話題下來,我們得反問一下自己,什么是觀察者模式?

        概念

        觀察者模式(Observer):通常又被稱作為發布-訂閱者模式。它定義了一種一對多的依賴關系,即當一個對象的狀態發生改變的時候,所有依賴于它的對象都會得到通知并自動更新,解決了主體對象與觀察者之間功能的耦合。

        講個故事

        上面對于觀察者模式的概念可能會比較官方化,所以我們講個故事來理解它。

        A:是共產黨派往國民黨密探,代號 001(發布者)
        B:是共產黨的通信人員,負責與 A 進行秘密交接(訂閱者)

      1. A 日常工作就是在明面采集國民黨的一些情報
      2. B 則負責暗中觀察著 A
      3. 一旦 A 傳遞出一些有關國民黨的消息(更多時候需要對消息進行封裝傳遞,后面根據源碼具體分析)
      4. B 會立馬訂閱到該消息,然后做一些相對應的變更,比如說通知共產黨們做一些事情應對國民黨的一些動作。
      5. 適用性

        以下任一場景都可以使用觀察者模式

      6. 當一個抽象模型有兩個方面,其中一個方面依賴于另一方面。講這兩者封裝在獨立的對象中可以讓它們可以各自獨立的改變和復用
      7. 當一個對象的改變的時候,需要同時改變其它對象,但是卻不知道具體多少對象有待改變
      8. 當一個對象必須通知其它對象,但是卻不知道具體對象到底是誰。換句話說,你不希望這些對象是緊密耦合的。
      9. 以下是我對vue觀察者模式的理解:

        不要對框架的偏見, 你真的了解jquery、angular、react 等等,框架是什么只是工具而已。

        你用過jquery的 trigger、on、off 事件綁定的方法嗎?事實上 vue 不過也是這種模式,只不過vue 是自動調用on方法,自動觸發trigger。甚至可以不用jquery對事件監聽觸發的實現。其實最終解釋就是對某種事件的callback(基礎原理)。

        以下是源碼目錄截圖:


        1... vue 實例初始化時,會對data函數返回的對象里的屬性調用以下方法,代碼注釋如下:

        // 這個是 vue 綁定自動綁定事件的方法和觸發事件方法, 會把data函數返回的對象變量屬性,重寫對應屬性的 賦值 和獲取的操作。具體查看 (mdn Object.defineProperty api)
         Object.defineProperty(obj, key, {
         enumerable: true,
         configurable: true,
         get: function reactiveGetter () {
         const value = getter ? getter.call(obj) : val
         // watcher 對象, 如果存在
         if (Dep.target) {
         // 把Watcher 實例 推入 Dep 實例的 subs 數組里, 這個就相當于 on
         dep.depend()
         if (childOb) {
         childOb.dep.depend()
         if (Array.isArray(value)) {
         dependArray(value)
         }
         }
         }
         return value
         },
         set: function reactiveSetter (newVal) {
         const value = getter ? getter.call(obj) : val
         /* eslint-disable no-self-compare */
         if (newVal === value || (newVal !== newVal && value !== value)) {
         return
         }
         /* eslint-enable no-self-compare */
         if (process.env.NODE_ENV !== 'production' && customSetter) {
         customSetter()
         }
         if (setter) {
         setter.call(obj, newVal)
         } else {
         val = newVal
         }
         childOb = !shallow && observe(newVal)
         // 通知 Dep 實例 中subs 里數組 中所有 Watcher 實例, 然后調用Watcher實例里的 update方法(), 這個就相當于 trigger。
         dep.notify()
         }
         })
        // Watcher 構造函數 
         constructor (
         vm: Component,
         expOrFn: string | Function,
         cb: Function,
         options?: ?Object,
         isRenderWatcher?: boolean
         )

        2...Watcher初始化時,會調用Dep.pushTarget方法, 把 Wathcer實例賦值到dep.js 里的Dep.target, 接著會根據 exporFn,運行exporFn 所代表的方法。這個方法里基本上包含調用 1...里的getter方法(想想render鉤子里的操作基本有獲取vue實例屬性data里的值或者獲取vue實例的計算屬性的值)。

        var vm = new Vue({
         data () {
         return {msg: '找個小姐姐!'}
         },
         // 相當于 exporFn
         render(h) {
         return h('h3', {},
         // 這里面就會調用 msg 對應的 getter方法
         this.msg
         )
         }
        })

        所以就會使 render 函數 與 Vue 實例 的 數據 data屬性 和觀察屬性等產生聯系,這就形成一個閉環。當其中的屬性變化,就會自動調用 setter 方法,從而觸發dep.notify 方法,進而又會觸發 dep.subs 里的 Watcher 實例調用 update方法,進而更新。
        (這部分代碼不知如何說,故此沒寫, 具體查看源碼)

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        vue觀察模式淺析

        vue觀察模式淺析:觀察者模式 首先話題下來,我們得反問一下自己,什么是觀察者模式? 概念 觀察者模式(Observer):通常又被稱作為發布-訂閱者模式。它定義了一種一對多的依賴關系,即當一個對象的狀態發生改變的時候,所有依賴于它的對象都會得到通知并自動更新,解決了主
        推薦度:
        標簽: 模式 VUE 觀察
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲永久永久永久永久永久精品| 国产亚洲?V无码?V男人的天堂| 亚洲国产精久久久久久久| 亚洲精品偷拍视频免费观看| 亚洲乱码中文字幕手机在线| 免费精品国自产拍在线播放| 亚洲国产日韩成人综合天堂| 国产激情久久久久影院老熟女免费 | 免费无码又爽又刺激一高潮| 亚洲人色婷婷成人网站在线观看| a毛片在线免费观看| 亚洲日本在线看片| 国产精品入口麻豆免费观看| 亚洲一线产品二线产品| 国产免费AV片无码永久免费| a免费毛片在线播放| 亚洲AV成人片色在线观看高潮| 91av免费观看| 亚洲国产精品无码中文lv| 免费一看一级毛片人| 中文字幕免费在线看电影大全 | 免费在线观影网站| 亚洲精品福利在线观看| 成年女性特黄午夜视频免费看| 国产精品亚洲а∨无码播放不卡| 91麻豆精品国产自产在线观看亚洲 | 亚洲一区无码中文字幕乱码| 日本一道在线日本一道高清不卡免费 | 国产成人一区二区三区免费视频 | 男人j进女人p免费视频| 亚洲午夜久久久久久噜噜噜| 最近高清中文字幕免费| 亚洲av午夜精品无码专区| 又粗又大又猛又爽免费视频| 久9热免费精品视频在线观看| 亚洲愉拍一区二区三区| 亚洲欧洲成人精品香蕉网| 久久久久免费看黄A片APP| 一级毛片完整版免费播放一区| 久久久久久久亚洲Av无码| 四虎永久免费观看|