React 如何仅更新真实 DOM 树的单个部分?

如何解决React 如何仅更新真实 DOM 树的单个部分?

React 的虚拟 DOM 如何仅渲染 DOM 的特定部分并保留树的其余部分?

不确定我是否正确,但如果我更改普通 HTML 文件中 Div 的内容,我将必须刷新页面才能看到更改,对吗?这意味着我必须重新绘制整个东西,重新创建整个 DOM 树。我不能自己直接“仅”更新 Div 元素。我需要刷新页面并重新创建整个树。

我知道虚拟 DOM 是什么,它如何将新版本与旧版本进行比较,以及诸如此类的东西。我还阅读了对帐文件,但这也没有回答我的问题。当 React 拥有需要转换为真实 DOM 的新虚拟 DOM 后会发生什么?

我想问的是:本质上,React 只是普通的 HTML 和 JS,最终必须成为真正的 DOM。那么他们如何只更新 DOM 中的单个 Div 元素而不需要重新加载整个页面呢?因为如果我们在 HTML 中手动执行此操作,则需要刷新整个页面才能看到更改,而且据我所知,我们不能像 React 那样自己更新其中的一部分。

解决方法

简短的回答是您不必重新加载页面来更新 DOM 树。您可以通过检查任何元素并编辑其内容来自己尝试。 React 也可以以类似的方式更新 DOM。这是即时的,因为内容在内存中而不是保存在文件中(需要重新加载)。

DOM 更新示例 :)

enter image description here

,

您可以使用 javascript 更新 DOM。更新文件时需要重新加载页面而反应不需要的原因是因为当您在浏览器中加载页面时,浏览器会将页面文件加载到它的内存中/您的 ram 执行代码(html、css 和javascript)。用于更新 DOM 的响应代码位于页面的 javascript 中。

但是,如果您更改文件中的 html,chrome 不知道所以不会知道,因此您必须重新加载页面以让 chrome 将新页面资源加载到它的内存中并执行任何代码有。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?