他说,尽管每一秒我们都会新建一个描述整个 UI 树的元素,React DOM 只会更新实际改变了的内容,也就是例子中的文本节点。
那是不是就是说,页面上的所有内容其实是整体都刷新了的,只不过是只有一部分内容改变了有一部分没变。
1
noe132 2022-07-12 19:13:20 +08:00
不是。
更新整个 UI 树说的是 vdom ,是在内存中的 javascript 对象。 通过对上一次的 vdom 树 和新的 vdom 树做 diff ,就知道哪些地方不同 然后再将不同的地方用 react dom 更新真实的 dom 。 简单来说就是每次更新都会执行一遍 render 函数,通过 render 出来的差异来做更新 |
2
cutemurphy2000 2022-07-12 19:38:10 +08:00
整体更新 那还不如 innerHTML
|
3
rabbbit 2022-07-12 19:47:20 +08:00
虚拟 DOM 更新了,真正的 DOM 只更新变化了的部分
|
4
placeholder OP @noe132 大概明白了,谢谢
|
5
placeholder OP @rabbbit 好的,谢谢
|