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

React 为什么重新渲染

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

1.7K30

基础 | React怎么判断什么时候该重新渲染组件

但是,React的智能仅此而已(目前为止),我们的任务是知道React的预期行为以及限制,这样我们才不会意外损失性能。 我们需要关注的一方面是React如何决定什么时候重新渲染组件。...组件获得新的状态然后React决定是否应该重新渲染组件。不幸的是,React难以置信简单地将默认行为设计为每次都重新渲染组件改变?重新渲染。父组件改变?重新渲染。...好吧,但是每次都重新渲染没有什么帮助。 我的意思是,我非常感谢React的细心谨慎。如果状态改变但是组件没有正确渲染的话更糟。权衡之下,每次都重新渲染绝对是一个安全的选择。...但是,React不能知道什么时候可以安全的跳过重新渲染,所以React无论是否重要每次都重新渲染。 我们如何告诉React跳过重新渲染? 那就是第二点要说的内容。...当React将要渲染组件时他会执行shouldComponentUpdate方法来看它是否返回true(组件应该更新,也就是重新渲染)。

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

React性能探索 --- 避免不必要渲染

背景 上一篇文章的结尾 https://cloud.tencent.com/developer/article/1009611 我们说到,也许,不是所有的节点都需要重新渲染,对于那些不需要渲染的节点,我们如何找到它们并做优化呢...感兴趣的同学可以下载跑一跑代码 分析更新时间 这里用react的Perf工具来测量重新渲染的时间。...如何修复 既然是不需要渲染,那就要阻止它的渲染。...对于上面的写法,React提供了一个新的组件PureComponent来做这件事,它会自动浅对比props/state,当两者相同的时候不渲染节点。...关于如何在实际中使用这两个组件,还要根据具体的实际情况来选择~ 总结 综上可以看出,减少不必要的重新渲染对于提升我们的性能有很大的意义。

1.1K60

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

在某些情况下,我们必须强制Vue重新渲染组件 虽然Vue不会自动更新这种情况是相对比较少,但是知道如何在出现这个问题时修复它还是很有用的。...这节,我们就来做一些之前很少做过或者没做过的:用 key 来让组件重新渲染。...在这篇文章中,会涉及到这几个知识点: key 是如何改变组件 key 如何与多个子组件一起工作 如何强制子组件自己更新 通过改变 key 的值来重新渲染组件 我最喜欢的方法是使用key属性,因为使用key...当componentKey 的值发生改变时,Vue 就知道把ComponentToReRender组件删除并创建一个新组件。 这样ComponentToReRender就会重新渲染并重置里面的状态。...child === 2) { this.key2 += 1; } } } } 这里我们使用了两个单独 key 来分别控制每个子组件是否重新渲染

4.2K30

分析 React 组件渲染性能

今天,我们介绍一下如何使用 React Profiler API 分析 React 组件渲染性能。 ? 出于演示目的,我们将使用一个电影排队 APP 。...import React, { Fragment, unstable_Profiler as Profiler} from "react"; Profiler 接受一个 onRender 回调函数,当被分析的渲染树中的组件提交更新时...phase: "mount" (首次挂载) 或 "update" (重新渲染),判断是组件树的第一次装载引起的重渲染,还是由 props、state 或是 hooks 改变引起的重渲染。...我们还可以打开 React DevTools ,转到 Profiler 选项卡并可视化我们的组件渲染时间。下面是火焰图视图: ?...我也喜欢使用排名视图,该视图已排序,因此渲染时间最长的组件显示在顶部: ?

3.4K10

React-组件-内联样式 和 React-组件-列表渲染优化

前言内联样式是一种强大的工具,它使开发人员能够在组件级别动态设置样式,而不必依赖外部CSS文件。...React 中的样式React 并没有像 Vue 那样有提供特定的区域给我们编写 CSS 代码所以你会发现在 React 代码中, CSS 样式的写法千奇百怪内联样式内联样式的优点:内联样式, 样式之间不会有冲突可以动态获取当前...state 中的状态内联样式的缺点:写法上都需要使用驼峰标识某些样式没有提示大量的样式, 代码混乱某些样式无法编写(比如伪类/伪元素)import React from 'react';class App...btnClick() { this.setState({ color: 'blue' }) }}export default App;列表渲染优化列表渲染优化由于...diff 算法在比较的时候默认情况下只会进行同层同位置的比较所以在渲染列表时可能会存在性能问题往后添加元素图片往前添加元素图片让 diff 算法递归比较同层所有元素给列表元素添加 key, 告诉 React

22020

关于各方面 杂七杂八的一些内容

、以及更新,然后再渲染....路由组件可以直接获取这些属性,而非路由组件就必须通过withRouter修饰后才能获取这些属性了,比如 App组件就可以直接获取路由中这些属性了...,但是,如果App组件中如果有一个子组件Foo, 那么Foo就不能直接获取路由中的属性了,必须通过withRouter修饰后才能获取到。...(2).withRouter是专门用来处理数据更新问题的.在使用一些redux的的connect()或者mobx的inject(), 如果依赖于路由的更新要重新渲染,会出现路由更新了但是组件没有重新渲染的情况...={() => } 3.改用render避免重复创建匿名组件render={() => } render形式主要是为了向路由组件里传递参数,component形式无法传递参数.

2K10

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

---- 有时候,依赖 Vue 响应方式来更新数据是不够的,相反,我们需要手动重新渲染组件来更新数据。或者,我们可能只想抛开当前的DOM,重新开始。那么,如何让Vue以正确的方式重新呈现组件呢?...强制 Vue 重新渲染组件的最佳方法是在组件上设置:key。 当我们需要重新渲染组件时,只需更 key 的值,Vue 就会重新渲染组件。 这是一个非常简单的解决方案。...所以就像上一个方法,如果你需要这个来重新渲染你的组件,可能有一个更好的方法。...为什么我们需要在 Vue 中使用 key 一旦你理解了这一点,那么这是了解如何以正确方式强制重新渲染的很小的一步。...更改 key 以强制重新渲染组件 最后,这是强制Vue重新渲染组件的最佳方法(我认为)。 我们可以采用这种将key分配给子组件的策略,但是每次想重新渲染组件时,只需更新该key即可。

7.5K20

应用connected-react-router和redux-thunk打通react路由孤立

组件不是一个“路由组件”,即组件并没有像这样渲染。...在使用一些 redux 的connect()或者 mobx的inject()的组件中,如果依赖于路由的更新要重新渲染,会出现路由更新了但是组件没有重新渲染的情况。...FETCH_POSTS_SUCCESS', response: { ... } } 所以想要实现异步操作需要做到: 操作开始时,发出一个 Action,触发 State 更新为“正在操作”,View 重新渲染...fetchPosts 代码如下: 操作结束后,再发出一个 Action,触发 State 更新为“操作结束”,View 再次重新渲染redux-thunk异步操作至少送出两个 Action,第一个 Action...跟同步操作一样,直接送出即可,那么如何送出第二个 Action 呢?

2.3K00

React 代码共享最佳实践方式

React官方在实现一些公共组件时,也用到了高阶组件,比如react-router中的withRouter,以及Redux中的connect。在这以withRouter为例。...高阶组件中的withRouter作用是将一个没有被Route路由包裹的组件,包裹到Route里面,从而将react-router的三个对象history、location、match放入到该组件的props...类型的属性,组件可以调用该props属性来实现组件内部渲染逻辑”。...(也可以叫做其他名字)的props属性,该属性是一个函数,并且这个函数返回了一个React Element,在组件内部通过调用该函数来完成渲染,那么这个组件就用到了render props技术。...读者或许会疑惑,“我们为什么需要调用props属性来实现组件内部渲染,而不直接在组件内完成渲染”?

3K20

三种React代码复用技术

React 代码复用 如何自己编写一个 react hook?react 允许我们自己编写 Hook。 场景 我们有几个组件,它们都要先进行 ajax 请求,获取到数据,然后把数据渲染到页面上。...高阶组件 如果要使用高阶组件的形式复用代码逻辑,就需要写一个函数,这个函数接收 React 组件作为参数,然后再返回一个新的 React 组件。...// 多层嵌套 withRouter 和 withFetch 如果使用了同样的 props 时,会有冲突 export default withRouter(withFetch(MyComponent)...,使用 组件 + render 回调的方式避免的 props 的属性值覆盖问题。...但,render-props 也有一些缺点,比如如果 render 里渲染的数据也要使用 render-props 的方式渲染组件,就会出现多级嵌套。

2.3K10

react进阶」一文吃透React高阶组件(HOC)

2 有几种高阶组件,它们优缺点是什么? 3 如何写一个优秀高阶组件? 4 hoc怎么处理静态属性,跨层级ref等问题? 5 高阶组件怎么控制渲染,隔离渲染? 6 高阶组件怎么监控原始组件的状态?...代表作react-router中的withRouter。...可以完全控制业务组件渲染与否,可以避免反向继承带来一些副作用,比如生命周期的执行。 ④ 可以嵌套使用,多个hoc是可以嵌套使用的,而且一般不会限制包装HOC的先后顺序。...如图所示,当我们只有点击 num++时候,才重新渲染组件,点击其他按钮,只是负责传递了props,达到了期望的效果。 ② 进阶:定制化渲染流 思考:?...,会重新挂载,状态会全都丢失。

1.8K30

React 进阶 - React Router

,也需要容器组件通过路由更新,来渲染视图 在 History 核心基础上,增加了 Router ,Switch ,Route 等组件来处理视图渲染 React-Router-DOM 在 React-Router...是通过 context 上下文方式传递的路由信息 context 改变,会使消费 context 组件更新,触发路由改变时,重新渲染匹配组件 props.history 是通过 BrowserRouter...Redirect ,导致路由页面无法展示 # 从路由改变到页面跳转 当用户触发 history.push ,或者点击浏览器前进后退,路由改变到页面重新渲染流程。... ) } } withRouter 对于距离路由组件比较远的深层次组件,通常可以用 React-Router...提供的 withRouter 高阶组件方式获取 histroy ,loaction 等信息 import { withRouter } from "react-router-dom" @withRouter

1.8K21
领券