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

Vue的虛擬DOM和diff算法你了解嗎

 更新時(shí)間:2022年02月10日 15:52:41   作者:旺仔流奶  
這篇文章主要為大家詳細(xì)介紹了Vue的虛擬DOM和diff算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助

在vue 中

數(shù)據(jù)改變 -> 虛擬DOM(計(jì)算變更)-> 操作DOM -> 視圖更新

虛擬DOM: js執(zhí)行速度比較快

什么是虛擬DOM?

用JS模擬DOM結(jié)構(gòu)

為什么需要虛擬DOM?

vue中 數(shù)據(jù)驅(qū)動(dòng)視圖,需要用高效方法來(lái)控制DOM操作的次數(shù)

diff算法: 虛擬DOM的核心

patch函數(shù)

兩個(gè)使用場(chǎng)景:

首次渲染時(shí),判斷第一個(gè)參數(shù)是否是一個(gè)真實(shí)dom元素,是的話就創(chuàng)建空vnode,并且關(guān)聯(lián)一個(gè)DOM元素,然后比較patch函數(shù)傳入的第一個(gè)參數(shù)和第二個(gè)參數(shù)是否是同一個(gè)vnode,如果是同一個(gè)vnode,那么就直接patchVnode做更新,如果是不同的vnode,那么就創(chuàng)建新的DOM元素,插入,并且把老的DOM元素刪除。

patchVnode函數(shù):

updateChildren函數(shù):

DOM Diff

對(duì)比兩個(gè)虛擬節(jié)點(diǎn),找出他們的差異,然后對(duì)應(yīng)到真實(shí)DOM節(jié)點(diǎn) 去打補(bǔ)?。╬atch)的過(guò)程

目的:以最小的代價(jià)來(lái)去修改DOM

虛擬節(jié)點(diǎn):將真實(shí)DOM用一個(gè)對(duì)象來(lái)表達(dá)出來(lái)。

defineProperty Proxy的區(qū)別:

本質(zhì)上有不同,所以使用上有所不同。

defineProperty 本質(zhì)是給對(duì)象增加屬性用的,所以在修改數(shù)組長(zhǎng)度,用索引設(shè)置數(shù)組的值,數(shù)組的push(),pop() 是無(wú)法觸發(fā)

defineProperty 中的set 的。所以Vue2中是使用自己定義的一些數(shù)組方法來(lái)實(shí)現(xiàn)的。

Proxy 沒(méi)有這個(gè)缺點(diǎn)。

Vue2 中不使用Proxy的原因是因?yàn)閜roxy是屬于ES6,當(dāng)時(shí)考慮的是兼容性的問(wèn)題。

Reflect 反射 內(nèi)置對(duì)象 方法集合的容器

Reflect 的好處:

之前的好多方法都掛在Object上,就很混亂。

未來(lái)很多方法都會(huì)逐漸放在Reflect上,成為內(nèi)置方法的容器,統(tǒng)一管理各種方法。

Reflect.has(obj,'a') // 函數(shù)式編程。

對(duì)比 'a' in obj

Object中的方法有些會(huì)直接拋出異常,需要包裹try catch

而Reflect中的方法一般都有返回值,失敗后會(huì)合理返回。

Proxy 中handler中的方法 和Reflect中的方法是一一對(duì)應(yīng)的。

Reflect 是ES6中全局的內(nèi)置對(duì)象。直接保存的靜態(tài)方法,不需要實(shí)例化,可以直接使用。

總結(jié)

本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!    

相關(guān)文章

  • vue.js使用watch監(jiān)聽(tīng)路由變化的方法

    vue.js使用watch監(jiān)聽(tīng)路由變化的方法

    這篇文章主要介紹了vue.js使用watch監(jiān)聽(tīng)路由變化的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-07-07
  • Element實(shí)現(xiàn)表格嵌套、多個(gè)表格共用一個(gè)表頭的方法

    Element實(shí)現(xiàn)表格嵌套、多個(gè)表格共用一個(gè)表頭的方法

    這篇文章主要介紹了Element實(shí)現(xiàn)表格嵌套、多個(gè)表格共用一個(gè)表頭的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • Vue實(shí)現(xiàn)文本展開收起功能

    Vue實(shí)現(xiàn)文本展開收起功能

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)文本展開收起功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue中的雙向數(shù)據(jù)綁定原理與常見(jiàn)操作技巧詳解

    vue中的雙向數(shù)據(jù)綁定原理與常見(jiàn)操作技巧詳解

    這篇文章主要介紹了vue中的雙向數(shù)據(jù)綁定原理與常見(jiàn)操作技巧,結(jié)合實(shí)例形式詳細(xì)分析了vue中雙向數(shù)據(jù)綁定的概念、原理、常見(jiàn)操作技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2020-03-03
  • Vue中ElementUI分頁(yè)組件Pagination的使用方法

    Vue中ElementUI分頁(yè)組件Pagination的使用方法

    這篇文章主要為大家詳細(xì)介紹了Vue中ElementUI分頁(yè)組件Pagination的使用,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • Vue 表情包輸入組件的實(shí)現(xiàn)代碼

    Vue 表情包輸入組件的實(shí)現(xiàn)代碼

    這篇文章主要介紹了Vue 表情包輸入組件的實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • Vue+SpringBoot實(shí)現(xiàn)支付寶沙箱支付的示例代碼

    Vue+SpringBoot實(shí)現(xiàn)支付寶沙箱支付的示例代碼

    本文主要介紹了Vue+SpringBoot實(shí)現(xiàn)支付寶沙箱支付的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-06-06
  • Vue.js劃分組件的方法

    Vue.js劃分組件的方法

    這篇文章主要介紹了Vue.js劃分組件的方法,需要的朋友可以參考下
    2017-10-10
  • axios發(fā)送post請(qǐng)求,提交圖片類型表單數(shù)據(jù)方法

    axios發(fā)送post請(qǐng)求,提交圖片類型表單數(shù)據(jù)方法

    下面小編就為大家分享一篇axios發(fā)送post請(qǐng)求,提交圖片類型表單數(shù)據(jù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • vue實(shí)現(xiàn)目錄樹結(jié)構(gòu)

    vue實(shí)現(xiàn)目錄樹結(jié)構(gòu)

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)目錄樹結(jié)構(gòu),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評(píng)論