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

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

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

在vue 中

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

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

什么是虛擬DOM?

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

為什么需要虛擬DOM?

vue中 數(shù)據(jù)驅(qū)動(dòng)視圖,需要用高效方法來控制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ǔ)丁(patch)的過程

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

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

defineProperty Proxy的區(qū)別:

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

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

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

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

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

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

Reflect 的好處:

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

未來很多方法都會(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é)

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

相關(guān)文章

最新評(píng)論