V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
placeholder
V2EX  ›  问与答

关于 react 教程中, react 只更新它需要更新的部分这一章节

  •  
  •   placeholder · 2022-07-12 19:10:19 +08:00 · 894 次点击
    这是一个创建于 858 天前的主题,其中的信息可能已经有所发展或是发生改变。

    他说,尽管每一秒我们都会新建一个描述整个 UI 树的元素,React DOM 只会更新实际改变了的内容,也就是例子中的文本节点。

    那是不是就是说,页面上的所有内容其实是整体都刷新了的,只不过是只有一部分内容改变了有一部分没变。

    教程页面

    5 条回复    2022-07-12 21:16:54 +08:00
    noe132
        1
    noe132  
       2022-07-12 19:13:20 +08:00
    不是。
    更新整个 UI 树说的是 vdom ,是在内存中的 javascript 对象。
    通过对上一次的 vdom 树 和新的 vdom 树做 diff ,就知道哪些地方不同
    然后再将不同的地方用 react dom 更新真实的 dom 。

    简单来说就是每次更新都会执行一遍 render 函数,通过 render 出来的差异来做更新
    cutemurphy2000
        2
    cutemurphy2000  
       2022-07-12 19:38:10 +08:00
    整体更新 那还不如 innerHTML
    rabbbit
        3
    rabbbit  
       2022-07-12 19:47:20 +08:00
    虚拟 DOM 更新了,真正的 DOM 只更新变化了的部分
    placeholder
        4
    placeholder  
    OP
       2022-07-12 21:16:27 +08:00
    @noe132 大概明白了,谢谢
    placeholder
        5
    placeholder  
    OP
       2022-07-12 21:16:54 +08:00
    @rabbbit 好的,谢谢
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1118 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 18:59 · PVG 02:59 · LAX 10:59 · JFK 13:59
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.