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

深入了解Vue中雙向數(shù)據(jù)綁定原理

 更新時間:2022年05月19日 09:48:39   作者:幾何心涼  
vue是一個mvvm框架,即數(shù)據(jù)雙向綁定,即當數(shù)據(jù)發(fā)生變化的時候,視圖也就發(fā)生變化,當視圖發(fā)生變化的時候,數(shù)據(jù)也會跟著同步變化。本文將通過示例詳解其中原理,需要的可以參考一下

數(shù)據(jù)的變化反應到視圖

前面我們了解到數(shù)據(jù)劫持之后,我們可以在數(shù)據(jù)發(fā)生修改之后做任何我們想要做的事情,操作視圖當然也是OK的

命令式操作視圖

目標:我們通過原始的操作dom的方式讓每一次的name的最新值都能顯示到p元素內(nèi)部

<div id="app">
  <p></p>
</div>
<script>
   let data = {
        name: '小蘭同學',
        age: 18,
        height:180
    }
    // 遍歷每一個屬性
    Object.keys(data).forEach((key)=>{
        // key 屬性名
        // data[key] 屬性值
        defineReactive(data,key,data[key])
    })
    function defineReactive(data,key,value){
        Object.defineProperty(data,key,{
            get(){
               return value
            },
            set(newVal){
              value = newVal 
              // 數(shù)據(jù)發(fā)生變化,操作dom進行更新
              document.querySelector('#app p').innerHTML = data.name
            }
        })
    }
  // 首次渲染
  document.querySelector('#app p').innerHTML = data.name
</script>

聲明式操作視圖

目標:我們將data中name屬性的值作為文本渲染到標記了v-text的p標簽內(nèi)部,在vue中,我們把這種標記式的聲明式渲染叫做指令

<div id="app">
  <p v-text="name"></p>
</div>
<script>
  let data = {
    name: '小蘭同學',
    age: 18,
    height: 180
  }
  // 遍歷每一個屬性
  Object.keys(data).forEach((key) => {
    // key 屬性名
    // data[key] 屬性值
    // data 原對象
    defineReactive(data, key, data[key])
  })
  function defineReactive(data, key, value) {
    Object.defineProperty(data, key, {
      get() {
        return value
      },
      set(newVal) {
        value = newVal
        // 數(shù)據(jù)發(fā)生變化,操作dom進行更新
        compile()
      }
    })
  }
  // 
  function compile() {
    let app = document.getElementById('app')
    // 1.拿到app下所有的子元素
    const nodes = app.childNodes   //  [text, input, text]
    //2.遍歷所有的子元素
    nodes.forEach(node => {
      // nodeType為1為元素節(jié)點
      if (node.nodeType === 1) {
        const attrs = node.attributes
        // 遍歷所有的attrubites找到 v-model
        Array.from(attrs).forEach(attr => {
          const dirName = attr.nodeName
          const dataProp = attr.nodeValue
          if (dirName === 'v-text') {
            node.innerText = data[dataProp]
          }
        })
      }
    })
  }
  // 首次渲染
  compile()
</script>

小結

不管是指令也好,插值表達式也好,這些都是將數(shù)據(jù)反應到視圖的標記而已,通過標記我們可以把數(shù)據(jù)的變化響應式的反應到對應的dom位置上去
找標記,把數(shù)據(jù)綁定到dom的過程,我們稱之為binding

視圖的變化反應到數(shù)據(jù)

目標:將data中的message屬性對應的值渲染到input上面,同時input值發(fā)生修改之后,可以反向修改message的值,在vue系統(tǒng)中,v-model指令就是干這個事情的,下面我們就實現(xiàn)一下v-model的功能

<div id="app">
  <input v-model="name" />
</div>
<script>
  let data = {
    name: '小蘭同學',
    age: 18,
    height: 170
  }
  // 遍歷每一個屬性
  Object.keys(data).forEach((key) => {
    // key 屬性名
    // data[key] 屬性值
    // data 原對象
    defineReactive(data, key, data[key])
  })
  function defineReactive(data, key, value) {
    Object.defineProperty(data, key, {
      get() {
        return value
      },
      set(newVal) {
        // 數(shù)據(jù)發(fā)生變化,操作dom進行更新
        if (newVal === value) {
          return
        }
        value = newVal
        compile()
      }
    })
  }
  // 編譯函數(shù)
  function compile() {
    let app = document.getElementById('app')
    // 1.拿到app下所有的子元素
    const nodes = app.childNodes   //  [text, input, text]
    //2.遍歷所有的子元素
    nodes.forEach(node => {
      // nodeType為1為元素節(jié)點
      if (node.nodeType === 1) {
        const attrs = node.attributes
        // 遍歷所有的attrubites找到 v-model
        Array.from(attrs).forEach(attr => {
          const dirName = attr.nodeName
          const dataProp = attr.nodeValue
          if (dirName === 'v-model') {
            node.value = data[dataProp]
            // 視圖變化反應到數(shù)據(jù) 無非是事件監(jiān)聽反向修改
            node.addEventListener('input', (e) => {
              data[dataProp] = e.target.value
            })
          }
        })
      }
    })
  }
  // 首次渲染
  compile()
</script>

現(xiàn)存的問題

無法做到精準更新

<div id="app">
  <p v-text="name"></p>
  <p v-text="age"></p>
  <p v-text="name"></p>
</div>
<script>
  let data = {
    name: '小蘭同學',
    age: 18,
    height: 180
  }
  // 遍歷每一個屬性
  Object.keys(data).forEach((key) => {
    // key 屬性名
    // data[key] 屬性值
    // data 原對象
    defineReactive(data, key, data[key])
  })
  function defineReactive(data, key, value) {
    Object.defineProperty(data, key, {
      get() {
        return value
      },
      set(newVal) {
        // 數(shù)據(jù)發(fā)生變化,操作dom進行更新
        if (newVal === value) {
          return
        }
        value = newVal
        compile()
      }
    })
  }
  // 編譯函數(shù)
  function compile() {
    let app = document.getElementById('app')
    // 1.拿到app下所有的子元素
    const nodes = app.childNodes   //  [text, input, text]
    //2.遍歷所有的子元素
    nodes.forEach(node => {
      // nodeType為1為元素節(jié)點
      if (node.nodeType === 1) {
        const attrs = node.attributes
        Array.from(attrs).forEach(attr => {
          const dirName = attr.nodeName
          const dataProp = attr.nodeValue
          console.log( dirName,dataProp)
          if (dirName === 'v-text') {
            console.log(`更新了${dirName}指令,需要更新的屬性為${dataProp}`)
            node.innerText = data[dataProp]
          }
        })
      }
    })
  }
  // 首次渲染
  compile()
</script>

以上就是深入了解Vue中雙向數(shù)據(jù)綁定原理的詳細內(nèi)容,更多關于Vue雙向數(shù)據(jù)綁定的資料請關注腳本之家其它相關文章!

相關文章

  • vue+ElementUI 關閉對話框清空驗證,清除form表單的操作

    vue+ElementUI 關閉對話框清空驗證,清除form表單的操作

    這篇文章主要介紹了vue+ElementUI 關閉對話框清空驗證,清除form表單的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue2.0/3.0的響應式原理及區(qū)別淺析

    vue2.0/3.0的響應式原理及區(qū)別淺析

    這篇文章主要給大家介紹了關于vue2.0/3.0響應式原理及區(qū)別的相關資料,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-05-05
  • vue組件父子間通信詳解(三)

    vue組件父子間通信詳解(三)

    這篇文章主要為大家詳細介紹了vue組件父子間通信的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Vue的子組件props如何設置多個校驗類型

    Vue的子組件props如何設置多個校驗類型

    這篇文章主要介紹了Vue的子組件props如何設置多個校驗類型問題。具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Vue 中如何利用 new Date() 獲取當前時間

    Vue 中如何利用 new Date() 獲取當前時間

    在 Vue 開發(fā)中,利用 new Date() 方法可以方便地獲取當前時間,并通過 Date 對象的方法進行時間格式化和操作。通過本文的介紹,您應該對在 Vue 中獲取當前時間有了更深入的了解,并了解了一些常見的時間操作方法,需要的朋友可以參考下
    2023-07-07
  • 使用vue導出excel遇到的坑及解決

    使用vue導出excel遇到的坑及解決

    這篇文章主要介紹了使用vue導出excel遇到的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue選項之propsData傳遞數(shù)據(jù)方式

    Vue選項之propsData傳遞數(shù)據(jù)方式

    這篇文章主要介紹了Vue選項之propsData傳遞數(shù)據(jù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • VUE使用docxtemplater導出word文檔實例(帶圖片)

    VUE使用docxtemplater導出word文檔實例(帶圖片)

    docxtemplate支持的功能很多,語法包含變量替換、條件判斷、循環(huán)、列表循環(huán)、表格循環(huán)等,下面這篇文章主要給大家介紹了關于VUE使用docxtemplater導出word功能(帶圖片)的相關資料,需要的朋友可以參考下
    2023-06-06
  • Vue中CSS?scoped的原理詳細講解

    Vue中CSS?scoped的原理詳細講解

    在組件中增加的css加了scoped屬性之后,就在會在當前這個組件的節(jié)點上增加一個data-v-xxx屬性,下面這篇文章主要給大家介紹了關于Vue中CSS?scoped原理的相關資料,需要的朋友可以參考下
    2023-01-01
  • 解決vue.js 數(shù)據(jù)渲染成功仍報錯的問題

    解決vue.js 數(shù)據(jù)渲染成功仍報錯的問題

    今天小編就為大家分享一篇解決vue.js 數(shù)據(jù)渲染成功仍報錯的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08

最新評論