欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue2.0/3.0雙向數(shù)據(jù)綁定的實(shí)現(xiàn)原理詳解

 更新時(shí)間:2021年04月21日 10:12:07   作者:大·左  
這篇文章主要給大家介紹了關(guān)于Vue2.0/3.0雙向數(shù)據(jù)綁定的實(shí)現(xiàn)原理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

Vue2.0/3.0 雙向數(shù)據(jù)綁定的實(shí)現(xiàn)原理

雙向數(shù)據(jù)綁定簡意 即數(shù)據(jù)的改變能讓頁面重新渲染

Vue2.0 ES5的原理:

Object.defineProperty 對數(shù)據(jù)進(jìn)行攔截

簡單小案例

<body>
    姓名:
    <span id="name"></span>
    <br />
    <input type="text" id="inputName" />
  </body>

改變input框的值 讓span里面的值隨之改變 數(shù)據(jù)的改變可以讓視圖

 <script>
      let obj ={
          name:''
      }
      Object.defineProperty(obj,'name',{
          get(){
                return this.name    //注意錯(cuò)誤示范 不可以用this 形成死循環(huán) 要準(zhǔn)備一個(gè)新的值
          },
          set(val){

          }
      })
  </script>

正確寫法

<script>
      let obj = {
      name: ""
    };
    let newObj = JSON.parse(JSON.stringify(obj));
    Object.defineProperty(obj, "name", {
      get() {
        return newObj.name;
      },
      set(val) {
        if (val === newObj.name) return; //增加判斷優(yōu)化性能 判斷新值與舊值是否一樣 一樣就返回  不一樣的話的再次賦值
        newObj.name = val;
        obServer();
      }
    });
    //   重新賦值的方法
    function obServer() {
      spanName.innerHTML = newObj.name; //獲取obj.name的值
      inputName.value = newObj.name;
    }
    obServer(); //開始就執(zhí)行一次
    setTimeout(() => {
      obj.name = "大左";
    }, 1000);
  </script>

執(zhí)行邏輯

1.setTimeout執(zhí)行1秒后修改數(shù)據(jù) 觸發(fā)obj.name的set(val)

2.拿到最新的值給到newObj.name 執(zhí)行 obServer()方法

3.拿到最新的值賦值 spanName.innerHTML = newObj.name; inputName.value = newObj.name;

input框的值改變 span框的值隨著改變

inputName.oninput = function() {
      obj.name = this.value;
    };

這個(gè)操作在Vue 里面叫v-model

Vue2.0不足之處

1.需要對原始數(shù)據(jù)進(jìn)行克隆 不然死循環(huán) 上面有提到

2.如果我們想給對象中的數(shù)據(jù)進(jìn)行g(shù)et和set的攔截 就要一個(gè)個(gè)設(shè)置 對象中的屬性都要單獨(dú)的監(jiān)聽一下 如果有多個(gè)就要循環(huán)遍歷了 分別來監(jiān)聽了

反看vue2.0中的data

data(){
return{
obj:{}
}
}
this.obj.name='XXX'  //這個(gè)操作行不通  因?yàn)閯傞_始的時(shí)候obj里面沒有name所以就沒有進(jìn)行監(jiān)聽 都是以上第二條造成的

ok 那我們再看一下

3.0的特點(diǎn)以及好處

主要用到了SE6里面的proxy

 <script>
    let obj = {};
    obj = new Proxy(obj, {
      get(target, prop) {
        console.log("D");
        return target[prop];
      },
      set(target, prop, value) {
        console.log("Z");
        target[prop] = value;
      }
    }); //監(jiān)聽整個(gè)對象 不需要指定屬性 相當(dāng)于把對象里所有的屬性都監(jiān)聽了 So 直接寫整體的set get
  </script>

1.獲取obj.name 觸發(fā)get 這里沒有name 但是可以走 因?yàn)闆]有值所以返回undefine

2. 設(shè)置給name值看一下 觸發(fā)set

3.再次獲取obj.name看看有沒有值

So 不管你現(xiàn)在對象里有沒有某個(gè)屬性 因?yàn)檫@里監(jiān)聽的是整個(gè)對象 對象里面未來有的都有了 彌補(bǔ)2.0不足之處

1.不需要clone

2.也不需要給每一個(gè)對象里面的屬性單獨(dú)設(shè)置 給整體對象設(shè)置就ok了 干凈又衛(wèi)生啊

再次實(shí)現(xiàn)上面2.0的操作

 <script>
    let obj = {};
    obj = new Proxy(obj, {
      get(target, prop) {
        console.log("D");
        return target[prop];
      },
      set(target, prop, value) {
        console.log("Z");
        target[prop] = value;
        obServer();
      }
    }); //監(jiān)聽整個(gè)對象 不需要指定屬性 相當(dāng)于把對象里所有的屬性都監(jiān)聽了 So 直接寫整體的set get
    //   重新賦值的方法
    function obServer() {
      spanName.innerHTML = obj.name; //獲取obj.name的值
      inputName.value = obj.name;
    }
    obServer(); //開始就執(zhí)行一次
    setTimeout(() => {
      obj.name = "大左";
    }, 1000);
    inputName.oninput = function() {
      obj.name = this.value;
    };
  </script>

總結(jié)

到此這篇關(guān)于Vue2.0/3.0雙向數(shù)據(jù)綁定的實(shí)現(xiàn)原理的文章就介紹到這了,更多相關(guān)Vue雙向數(shù)據(jù)綁定原理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue中使用element-ui進(jìn)行表單驗(yàn)證的實(shí)例代碼

    vue中使用element-ui進(jìn)行表單驗(yàn)證的實(shí)例代碼

    這篇文章主要介紹了vue中使用element-ui進(jìn)行表單驗(yàn)證的實(shí)例代碼,本文給大家分享實(shí)現(xiàn)思路,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-06-06
  • vue 解決mintui彈窗彈起來,底部頁面滾動bug問題

    vue 解決mintui彈窗彈起來,底部頁面滾動bug問題

    這篇文章主要介紹了vue 解決mintui彈窗彈起來,底部頁面滾動bug問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue中內(nèi)置指令與自定義指令語法詳解

    Vue中內(nèi)置指令與自定義指令語法詳解

    這篇文章主要為大家介紹了Vue中內(nèi)置指令與自定義指令語法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • Nuxt.js實(shí)現(xiàn)一個(gè)SSR的前端博客的示例代碼

    Nuxt.js實(shí)現(xiàn)一個(gè)SSR的前端博客的示例代碼

    這篇文章主要介紹了Nuxt.js實(shí)現(xiàn)一個(gè)SSR的前端博客的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Vue前端vue.config.js簡介

    Vue前端vue.config.js簡介

    vue.config.js?是一個(gè)可選的配置文件,如果項(xiàng)目的?(和?package.json?同級的)?根目錄中存在這個(gè)文件,那么它會被?@vue/cli-service?自動加載,本文重點(diǎn)介紹VUE前端vue.config.js簡介,感興趣的朋友跟隨小編一起看看吧
    2023-01-01
  • 簡化vuex的狀態(tài)管理方案的方法

    簡化vuex的狀態(tài)管理方案的方法

    在 vuejs 相關(guān)項(xiàng)目開發(fā)過程中,我們常常會使用 vuex 作為狀態(tài)管理工具, 整個(gè)組件的狀態(tài)做為單向數(shù)據(jù)流的模式管理,這篇文章主要介紹了簡化vuex的狀態(tài)管理方案的方法,感興趣的小伙伴們可以參考一下
    2018-06-06
  • vue開發(fā)實(shí)現(xiàn)評論列表

    vue開發(fā)實(shí)現(xiàn)評論列表

    這篇文章主要為大家詳細(xì)介紹了vue開發(fā)實(shí)現(xiàn)評論列表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue.js動畫中的js鉤子函數(shù)的實(shí)現(xiàn)

    vue.js動畫中的js鉤子函數(shù)的實(shí)現(xiàn)

    這篇文章主要介紹了vue.js動畫中的js鉤子函數(shù)的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-07-07
  • springboot?vue接口測試前端動態(tài)增刪表單功能實(shí)現(xiàn)

    springboot?vue接口測試前端動態(tài)增刪表單功能實(shí)現(xiàn)

    這篇文章主要為大家介紹了springboot?vue接口測試前端動態(tài)增刪表單功能實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Vue 用Vant實(shí)現(xiàn)時(shí)間選擇器的示例代碼

    Vue 用Vant實(shí)現(xiàn)時(shí)間選擇器的示例代碼

    這篇文章主要介紹了Vue 用Vant實(shí)現(xiàn)時(shí)間選擇器的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10

最新評論