1. 介绍
在JS里写好DOM的数据结构,然后通过document.createElement放进页面里,在下次数据更新的时候和之前的数据对比,就可以只更新数据变化的部分,不用整个DOM都更新,提升了性能
2. JS实现DOM
data:image/s3,"s3://crabby-images/fe881/fe881a577069bc1e1d06f6ec77ddf526a0b66b31" alt=""
data:image/s3,"s3://crabby-images/f616d/f616da09a59a28d121f8db99d25ae386e22106c9" alt=""
3. 更新DOM
data:image/s3,"s3://crabby-images/f010c/f010ccafd9b7362722b4bfbda1f878723023c107" alt=""
只增加了最后一条,所以只需要更新最后一个span就行
data:image/s3,"s3://crabby-images/24f33/24f337d848ba8465234517d1c3e8a08788ca0143" alt=""
这个补丁函数不完美,若只是所有数据换个位置,则它也会替换整个DOM
const root = document.getElementById('root')
let vNode1 = v('div', [v('#text', 'hello')])
patchElement(root, vNode1)
let vNode2 = v('div', [v('#text', 'world')])
patchElement(root, vNode2, vNode1) // 更新
网友评论