亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

實現(xiàn)一個簡單得數(shù)據(jù)響應系統(tǒng)

 更新時間:2021年11月08日 10:49:08   作者:zz  
這篇文章主要介紹了實現(xiàn)一個簡單得數(shù)據(jù)響應系統(tǒng),文章介紹的數(shù)據(jù)響應系統(tǒng)會用到Dep,其實,這就是一個依賴收集的容器, depend 收集依賴, notify 觸發(fā)依賴,下面來看看詳細的內容結介紹,需要的朋友可以參考一下

1、Dep

其實,這就是一個依賴收集的容器, depend 收集依賴, notify 觸發(fā)依賴

class Dep{
  constructor() {
    this._subs = [];
  }
  depend () {
    this._subs.push(Dep.target)
  }
  notify() {
    this._subs.forEach(item => {
      item.fn();
    })
  }
}

// 其實就是 dep 和 watcher 基情滿滿的開始,watcher 中用到
// 通過一個全局屬性來存 watcher
Dep.target = null;

function pushTarget(watch) {
  Dep.target = watch;
}

function popTarget() {
  Dep.target = null;
}

2、了解 obverser

遞歸,將 data 對象所有屬性轉化為訪問器屬性

// 轉為訪問器屬性
function defineReactive (obj, key, val, shallow) {

  // 創(chuàng)建一個依賴收集容器
  let dep = new Dep();
  let childOb = !shallow && observe(val)

  Object.defineProperty(obj, key, {
    enumerable: true,
    configurable: true,
    get: function reactiveGetter () {
      if(Dep.target) {
        // 收集依賴
        dep.depend();
      }
      return val;
      // ...
    },
    set: function reactiveSetter (newVal) {
      if(newVal === val) return;
      // 繼續(xù)遞歸遍歷
      observe(newVal);
      // 觸發(fā)依賴
      dep.notify();
      // ...
    }
  })
}

class Observer{
  constructor(data) {
    this.walk(data);
  }

  walk(data) {
    const keys = Object.keys(data)
    for (let i = 0; i < keys.length; i++) {
      defineReactive(data, keys[i], data[keys[i]])
    }
  }
}

// 遞歸,將 data 對象所有屬性轉化為訪問器屬性
function observe (data) {
  if(Object.prototype.toString.call(data) !== '[object Object]') return;
  new Observer(data);
}

此時就可以把任意一個對象的全部屬性轉為訪問器

3、了解 watch 和 observer

const data = {
  a: 1,
  b: 2
}

// 首先監(jiān)控一個對象
observe(data);

watcher 的主要功能是檢測某個屬性,當屬性變化時觸發(fā)一個回調

class Watcher{
  /**
  * @params {Function} exp 一個屬性表達式
  * @params {Function} fn 回調
  */
  constructor(exp, fn) {
    this.exp = exp;
    this.fn = fn;

    // 存 watcher
    // Dep.target = this;
    pushTarget(this);

    // 先執(zhí)行一次表達式函數(shù),會在調用過程中,
    // 觸發(fā)到 data.a 的訪問器, data.a 的 get 被執(zhí)行,
    // 觸發(fā) dep.depend() 開始收集依賴
    this.exp();

    // 釋放 Dep.target
    popTarget();
  }
}

// new Watcher 這樣一個依賴就被收集了
new Watcher(() => {
  return data.a + data.b;
}, () => {
  console.log('change')
})

4、觸發(fā)依賴

data.a = 3; // change
data.b = 3; // change

5、總結一下流程

  • 把一個對象的全部屬性轉化為訪問器
  • 當為某一個屬性增加 watcher 時,會觸發(fā)改屬性的 get,get 函數(shù)中會把該 watcher 存到該屬性的 dep 依賴容器中
  • 當這個屬性發(fā)生變化時,會出發(fā)改屬性的 set 的方法,set 函數(shù)中會把 dep 存的依賴都執(zhí)行

到此這篇關于實現(xiàn)一個簡單得數(shù)據(jù)響應系統(tǒng)的文章就介紹到這了,更多相關數(shù)據(jù)響應系統(tǒng)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • JavaScript前端迭代器Iterator與生成器Generator講解

    JavaScript前端迭代器Iterator與生成器Generator講解

    這篇文章主要為大家介紹了JavaScript前端迭代器Iterator與生成器Generator講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 微信小程序 簡單教程實例詳解

    微信小程序 簡單教程實例詳解

    這篇文章主要介紹了微信小程序 簡單教程實例詳解的相關資料,這里對開發(fā)微信小程序步驟做了一一詳解,需要的朋友可以參考下
    2017-01-01
  • JavaScript架構搭建前端監(jiān)控如何采集異常數(shù)據(jù)

    JavaScript架構搭建前端監(jiān)控如何采集異常數(shù)據(jù)

    這篇文章主要為大家介紹了JavaScript架構搭建前端監(jiān)控如何采集異常數(shù)據(jù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • js實現(xiàn)兔年轉圈圈動畫示例

    js實現(xiàn)兔年轉圈圈動畫示例

    這篇文章主要為大家介紹了js實現(xiàn)兔年轉圈圈動畫示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • js的一些潛在規(guī)則示例分析

    js的一些潛在規(guī)則示例分析

    這篇文章主要為大家介紹了js的一些潛在規(guī)則示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • 微信小程序 網絡API發(fā)起請求詳解

    微信小程序 網絡API發(fā)起請求詳解

    這篇文章主要介紹了微信小程序 網絡API發(fā)起請求詳解的相關資料,需要的朋友可以參考下
    2016-11-11
  • JS實現(xiàn)大數(shù)相加大數(shù)相乘示例詳解

    JS實現(xiàn)大數(shù)相加大數(shù)相乘示例詳解

    這篇文章主要為大家介紹了JS實現(xiàn)大數(shù)相加大數(shù)相乘示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 自定義range?sliders滑塊實現(xiàn)元素拖動方法

    自定義range?sliders滑塊實現(xiàn)元素拖動方法

    這篇文章主要為大家介紹了自定義range?sliders滑塊實現(xiàn)元素拖動方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 在js中修改html body的樣式

    在js中修改html body的樣式

    這篇文章主要介紹了在js中修改html body的樣式,下面文章圍繞js修改html 和body樣式的相關資料展開詳細內容,需要的朋友可以參考一下,希望對大家有所幫助
    2021-11-11
  • JavaScript 運行機制詳解再淺談Event Loop

    JavaScript 運行機制詳解再淺談Event Loop

    這篇文章主要介紹了JavaScript 運行機制詳解及淺談了Event Loop,感興趣的小伙伴可以和小編一起閱讀下面文章的具體內容
    2021-09-09

最新評論