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

React 为什么重新渲染

更新(重新渲染)是 React 的重要特性 —— 当用户与应用交互的时候,React 需要重新渲染、更新 UI,以响应用户的输入。但是,React 为什么会重新渲染呢?...如果不知道 React 为什么会重新渲染,我们如何才能避免额外的重新渲染呢? TL; DR 状态改变是 React 树内部发生更新的唯二原因之一。 这句话是 React 更新的公理,不存在任何例外。...为了避免有人抬杠,这句话引入了一些限制定语和关键词: 名词解释 「更新」和「重新渲染」 在 React 中,「更新」和「重新渲染」是关系紧密,但是含义完全不同的两个词。...大部分开发者会把「更新」和「重新渲染」混为一谈,因为在上述三个阶段中,只有「渲染」这一阶段是开发者可以控制的(「Reconcilation」和「Commit」分别由 react-reconciler 和...本文接下来的部分中,「重新渲染」一律指代 React 组件在「更新」时的「渲染」阶段,而「更新」则一律指代(重新渲染、Reconcilation 和 Commit 整个过程。

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

    重新认识HTML渲染过程

    最近在学习李兵老师的浏览器工作原理与实践,才知道现在的渲染过程早已经不是这样了,很多概念都是刚知道。自己总结了一下过程和一些概念。...执行布局操作的时候,会把布局运算的结果重新写回布局树中,所以布局树既是输入内容也是输出内容,这是布局阶段一个不合理的地方,因为在布局阶段并没有清晰地将输入内容和输出内容区分开来。...输入内容是特点的节点,渲染引擎会把这些节点生成专用的图层,生成图层树。 5、图层绘制 完成图层树的构建之后,渲染引擎会对图层树中的每个图层进行绘制。...输入内容是图层树,通过渲染引擎输出绘制列表。 6、生成图块 绘制列表只是用来记录绘制顺序和绘制指令的列表,而实际上绘制操作是由渲染引擎中的合成线程来完成的。...重绘是改变颜色等,布局和分层不会重新执行。使用transform能跳过前面的阶段,直接进入合成阶段。 重新认识了一下渲染的过程,中间应该还是有很多的认知不足,现阶段也只能到这种程度了。

    1.5K30

    详解强制Vue组件重新渲染的方法

    在某些情况下,我们必须强制Vue重新渲染组件 虽然Vue不会自动更新这种情况是相对比较少,但是知道如何在出现这个问题时修复它还是很有用的。...这节,我们就来做一些之前很少做过或者没做过的:用 key 来让组件重新渲染。...在这篇文章中,会涉及到这几个知识点: key 是如何改变组件 key 如何与多个子组件一起工作 如何强制子组件自己更新 通过改变 key 的值来重新渲染组件 我最喜欢的方法是使用key属性,因为使用key...这样ComponentToReRender就会重新渲染并重置里面的状态。nice nice!...当然,还有更简单的方式,就是用div把列表包裹起来,直接对 div重新更新就行了: <Child v-for

    4.3K30

    Vue 中 强制组件重新渲染的正确方法

    强制 Vue 重新渲染组件的最佳方法是在组件上设置:key。 当我们需要重新渲染组件时,只需更 key 的值,Vue 就会重新渲染组件。 这是一个非常简单的解决方案。...假设我们要渲染具有以下一项或多项内容的组件列表: 有本地的状态 某种初始化过程,通常在created或mounted钩子中 通过jQuery或普通api进行无响应的DOM操作 如果你对该列表进行排序或以任何其他方式对其进行更新...,则需要重新渲染列表的某些部分。...但是,不会希望重新渲染列表中的所有内容,而只是重新渲染已更改的内容。 为了帮助 Vue 跟踪已更改和未更改的内容,我们提供了一个key属性。...所以接下来看看,如果使用最好的方法来重新渲染组件。 更改 key 以强制重新渲染组件 最后,这是强制Vue重新渲染组件的最佳方法(我认为)。

    7.8K20

    Vue路由嵌套刷新后页面没有重新渲染

    Vue路由嵌套刷新后页面没有重新渲染 强烈推介IDEA2020.2破解激活,IntelliJ...IDEA 注册码,2020.2 IDEA 激活码 问题 在路由嵌套时,如果此时地址栏到了子路由下面,刷新页面路由地址肯定不会有变化,那么此时会出现子路由页面没有重新渲染的情况。...解决方法 方法1 在子路由的容器在router-view中加上条件渲染 v-if ,默认为true。...让它显示出来,在父路由重新渲染完成后,将条件渲染的值变为false,在修改渲染条件数据之后使用 $nextTick,再将条件渲染的值变为true,相当于重新加载了一次子路由。...)=>{ this.routerAlive = true; }); } 方法2 其实上述方法的原理就是让浏览器认为是一个新的子路由,所以对其进行重新加载渲染

    1.5K30
    领券