首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用DocumentFragment优化DOM操作

它被作为一个轻量版的 Document 使用,就像标准的 document 一样,存储由节点(nodes)组成的文档结构。...#方法二 当然,更多能想到的方式应该是,先创造一个 div 节点,在内存中直接操作节点,然后把所有节点都凑在一起之后再跟 DOM 树进行交互,把所有节点都串在一个 div 上,然后再把 div 挂到 DOM...简单来说就是在内存中提供了一个 DOM 对象,当我们需要频繁操作 DOM 的时候,可以在内存先中创建一个 DocumentFragment 文档片段,然后对这个文档片段中进行一系列频繁的 DOM 操作,...当操作结束后直接插入真实的 DOM 节点中,这样所有的节点会被一次插入到真实的文档中,而这个操作仅发生一个重绘的操作。...操作的场景,可以使用DocumentFragment。

72410
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    DOM操作

    , 30 3月 2021 作者 847954981@qq.com 前端学习 DOM操作 在学习了JavaScript之后,我们会想,如何使用JavaScript来操纵HTML呢。...其实HTML中的每一个对象都是一个DOM对象,其以一种树状图形式表现 如图 1.树根是 DOCUMENT,也可以称为整个页面文档 2....每个 HTML 标签我们称之为 DOM 节点,英文为Node或者ELement 3. 每个 HTML 标签包裹的子标签,在树上体现为分支,称为儿子节点。比如上图,P和H1都是DIV的儿子节点。...那么我们知道了HTML的DOM间的关系,接下来我们需要的是去获取HTML的DOM来方便我们使用JavaScript进行修改 使用如下代码,获取main下的.core之后的.subtitle标签的DOM...(‘style’, ‘width: 100%; height: 100%;’);属性修改(可以修改class id 等等) dom.style.color = ‘xxxx’;具体属性修改 标签dom等等

    40320

    React DOM Diff算法

    遍历的key我们使用索引 class Person extends React.Component{ state = { persons:[ {id:1,...2.详细的说: 当状态中的数据发生变化时,react会根据【新数据】生成【新的虚拟DOM】,随后React进行【新虚拟DOM】与【旧虚拟DOM】的diff比较。 比较规则如下: a)....旧虚拟DOM中找到了跟新虚拟DOM相同的key: 1)若虚拟DOM内容没变,直接使用之前的真实DOM 2)若虚拟DOM中内容变了,则生成新的真实DOM,随后替换掉页面中之前的真实DOM...不要使用index作为key 因此最好不要使用index作为key,最好使用唯一标识 id 作为key 使用index作为key,可能会引发的问题 若对数据进行:逆序添加、逆序删除等破坏顺序的操作,会产生没有必要的真实...如果不存在对数据的逆序添加、逆序删除等破坏顺序的操作,仅仅用于展示,使用index是没有问题的。

    31730

    React 虚拟Dom渲染算法

    React提供了一系列声明性的API接口,因此在使用时不必担心每次库的更新会修改API接口。这样可以降低编写应用的复杂度,但是带来的问题是无法很好的理解React是如何实现这些功能的。...假设在我们使用React时,一共使用了1000个Dom标签元素,那么使用上面的算法,我们要比对数亿次才能得到比对的结果,根本不可能在一个浏览器中短时间完成。...差异算法 对于2颗有差异的树,React首先比对2颗树的根节点。根据跟节点的类型是否相同,算法接下来会执行不同的操作。...Dom元素拥有相同的类型 当比较React元素为相同类型时,React会查看元素上的属性来比对。...在某些极端情况下,虽然最终呈现效果并没有发生多大的变化,但是有可能每一个简单的操作都导致React全局重新渲染(例如列表没有Key)。

    80150

    React虚拟DOM的理解

    描述 在浏览器中构建页面时需要使用DOM节点描述整个文档。...这种方式赋予了React声明式的API,您告诉React希望让UI是什么状态,React就确保DOM匹配该状态,这样可以从属性操作、事件处理和手动DOM更新这些在构建应用程序时必要的操作中解放出来。...在React的世界里,术语Virtual DOM通常与React元素关联在一起,因为它们都是代表了用户界面的对象,而React也使用一个名为fibers的内部对象来存放组件树的附加信息,上述二者也被认为是...可以看出,因为要把变更应用到真实DOM上,所以还是避免不了要直接操作DOM,但是React的diff算法会把DOM改动次数降到最低。...React的出现,将命令式变成了声明式,摒弃了直接操作DOM的细节,只关注数据的变动,DOM操作由框架来完成,从而大幅度提升了代码的可读性和可维护性。

    83810
    领券