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

React 为什么重新渲染

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

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

    重新认识HTML渲染过程

    1、构建DOM树: 第一步构建DOM树都是一样的,DMO是document object module,是保存在内存中的树结构,可以通过js查询或修改其内容。...执行布局操作的时候,会把布局运算的结果重新写回布局树中,所以布局树既是输入内容也是输出内容,这是布局阶段一个不合理的地方,因为在布局阶段并没有清晰地将输入内容和输出内容区分开来。...输入内容是特点的节点,渲染引擎会把这些节点生成专用的图层,生成图层树。 5、图层绘制 完成图层树的构建之后,渲染引擎会对图层树中的每个图层进行绘制。...输入内容是图层树,通过渲染引擎输出绘制列表。 6、生成图块 绘制列表只是用来记录绘制顺序和绘制指令的列表,而实际上绘制操作是由渲染引擎中的合成线程来完成的。...重绘是改变颜色等,布局和分层不会重新执行。使用transform能跳过前面的阶段,直接进入合成阶段。 重新认识了一下渲染的过程,中间应该还是有很多的认知不足,现阶段也只能到这种程度了。

    1.5K30

    Headless Chrome:服务端渲染JS站点的一个方案【中篇】【翻译】防止重新渲染优化

    接上篇 防止重新渲染 其实说不对客户端代码做任何修改是忽悠人的。在我们的Express 应用中,通过Puppteer加载页面,提供给客户端响应,但是这个过程是有一些问题的。...js脚本在服务端的Headless Chrome 中执行过一次,但是等浏览器拿到真正的结果后,并不会阻止js再次执行,所以这种情况下js会执行两次(客户端一次,服务端一次) 针对我们的例子,我们可以简单的修复一下...,我们需要告诉页面,需要的html已经生成了,不需要再次生成了,所以我们可以简单的检测 是否在初始化时已存在,如果存在,说明在服务端已经渲染OK,没有必要重新渲染了。...-- Populated by JS (below) or by prerendering (server)....然后,我们实际上只关注两件事儿: 1.渲染后的Html 标签 2.能够生成标签的js请求 所以不构建Dom结果的网络请求都是浪费网络资源。比如图片、字体文件、样式文件和媒体资并不实际参与构建HTML。

    1.2K30

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

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

    4.3K30

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

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

    1.5K30

    爬虫遇到js动态渲染问题

    爬虫遇到js动态渲染问题 时间:2020年6月3日10:28:48 作者:钟健 概要:关于scrapy爬虫应对网页JavaScript动态渲染问题 关键字:scrapy crapy-splash...一、传统爬虫的问题 scrapy爬虫与传统爬虫一样,都是通过访问服务器端的网页,获取网页内容,最终都是通过对于网页内容的分析来获取数据,这样的弊端就在于他更适用于静态网页的爬取,而面对js渲染的动态网页就有点力不从心了...,因为通过js渲染出来的动态网页的内容与网页文件内容是不一样的。...做的动态渲染,所有数据都在js中间,这就使我们无法对于网页的结构进行分析来进行爬取数据 那我们如何,获取到它实际显示的页面,然后对页面内容进行分析呢?...其实大部分的动态网页的渲染,都存在与数据端进行请求交互数据,当然也存在一些,直接把数据存在js中间,然后再通过js渲染到网页上,这时候scrapy-splash就可以发挥价值了,尤其是在一些验证码,图形验证方面更加突出

    2K20

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

    我们需要关注的一方面是React如何决定什么时候重新渲染组件。不是重新渲染DOM节点,只是调用render方法来改变虚拟DOM。...组件获得新的状态然后React决定是否应该重新渲染组件。不幸的是,React难以置信简单地将默认行为设计为每次都重新渲染。 组件改变?重新渲染。父组件改变?重新渲染。...但是重新渲染的时间成本看起来非常昂贵(例子里非常夸张地表现了出来)。 是的,在不必要的时候重新渲染会浪费循环并且不是一个好的想好。...但是,React不能知道什么时候可以安全的跳过重新渲染,所以React无论是否重要每次都重新渲染。 我们如何告诉React跳过重新渲染? 那就是第二点要说的内容。...比起让React每次都重新渲染,你可以告诉React你什么时候不像触发重新渲染

    2.9K10
    领券