iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > html >JavaScript通过缓存React事件来提高性能
  • 525
分享到

JavaScript通过缓存React事件来提高性能

2024-04-02 19:04:59 525人浏览 独家记忆
摘要

这篇文章主要介绍“javascript通过缓存React事件来提高性能”,在日常操作中,相信很多人在JavaScript通过缓存React事件来提高性能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操

这篇文章主要介绍“javascript通过缓存React事件来提高性能”,在日常操作中,相信很多人在JavaScript通过缓存React事件来提高性能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript通过缓存React事件来提高性能”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

JavaScript中一个不被重视的概念是对象和函数是如何引用的,并且直接影响 React性能。  如果创建两个完全相同的函数,它们仍然不相等,试试下面的例子:

const functionOne = function() { alert('Hello world!'); };  const functionTwo = function() { alert('Hello world!'); };  functionOne === functionTwo; // false

但是,如果将变量指向一个已存在的函数,看看它们的差异:

const functionThree = function() { alert('Hello world!'); };  const functionFour = functionThree;  functionThree === functionFour; // true

对象的工作方式也是一样的。

const object1 = {}; const object2 = {}; const object3 = object1; object1 === object2; // false object1 === object3; // true

如果人有其他语言的经验,你可能熟悉指针。每次创建一个对象,计算机会为这个对象分配了一些内存。当声明 object1 ={} 时,已经在用户电脑中的  RAM(随机存取存储器) 中创建了一个专门用于object1 的字节块。可以将 object1 想象成一个地址,其中包含其键-值对在 RAM 中的位置。

当声明 object2 ={} 时,在用户的电脑中的 RAM 中创建了一个专门用于 object2 的不同字节块。object1 的地址与 object2  的地址是不一样的。这就是为什么这两个变量的等式检查没有通过的原因。它们的键值对可能完全相同,但是内存中的地址不同,这才是会被比较的地方。

当我赋值 object3 = object1 时,我将 object3 的值赋值为 object1  的地址,它不是一个新对象。它们在内存中的位置是相同的,可以这样验证:

const object1 = { x: true };  const object3 = object1;  object3.x = false;  object1.x; // false

在本例中,我在内存中创建了一个对象并取名为 object1。然后将 object3 指向 object1 这时它们的内存的地址中是相同的。

通过修改 object3,可以改变对应内存中的值,这也意味着所有指向该内存的变量都会被修改。obect1 的值也被改变了。

对于初级开发人员来说,这是一个非常常见的错误,可能需要一个更别深入的教程,但是本广是关于React 性能的,只是本文是讨论 React  性能的,甚至是对变量引用有较深资历的开发者也可能需要学习。

这与 React 有什么关系? React 有一种节省处理时间以提高性能的智能方法:如果组件的 props 和 state 没有改变,那么render  的输出也一定没有改变。 显然,如果所有的都一样,那就意味着没有变化,如果没有任何改变,render 必须返回相同的输出,因此我们不必执行它。 这就是 React  快速的原因,它只在需要时渲染。

React 采用和 JavaScript 一样的方式,通过简单的 == 操作符来判断 props 和 state 是否有变化。  React不会深入比较对象以确定它们是否相等。浅比较用于比较对象的每个键值对,而不是比较内存地址。深比较更进一步,如果键-值对中的任何值也是对象,那么也对这些键-值对进行比较。React  都不是:它只是检查引用是否相同。

如果要将组件的 prop 从 {x:1} 更改为另一个对象 {x:1},则 React 将重新渲染,因为这两个对象不会引用内存中的相同位置。  如果要将组件的 prop 从 object1(上面的例子)更改为 o bject3,则 React 不会重新呈现,因为这两个对象具有相同的引用。

在 JavaScript 中,函数的处理方式是相同的。如果 React 接收到具有不同内存地址的相同函数,它将重新呈现。如果 React  接收到相同的函数引用,则不会。

不幸的是,这是我在代码评审过程中遇到的常见场景:

class SomeComponent extends React.PureComponent {   get instructions () {     if (this.props.do) {       return 'click the button: '     }     return 'Do NOT click the button: '   }    render() {     return (       <div>         {this.instructions}         <Button onClick={() => alert('!')} />       </div>     )   } }

这是一个非常简单的组件。 有一个按钮,当它被点击时,就 alert。 instructions 用来表示是否点击了按钮,这是通过  SomeComponent 的 prop 的 do={true} 或 do={false} 来控制。

这里所发生的是,每当重新渲染 SomeComponent 组件(例如 do 从 true 切换到 false)时,按钮也会重新渲染,尽管每次  onClick 方法都是相同的,但是每次渲染都会被重新创建。

每次渲染时,都会在内存中创建一个新函数(因为它是在 render 函数中创建的),并将对内存中新地址的新引用传递给<Button />,虽然输入完全没有变化,该 Button 组件还是会重新渲染。

修复

如果函数不依赖于的组件(没有 this 上下文),则可以在组件外部定义它。  组件的所有实例都将使用相同的函数引用,因为该函数在所有情况下都是相同的。

const createAlertBox = () => alert('!');  class SomeComponent extends React.PureComponent {    get instructions() {     if (this.props.do) {       return 'Click the button: ';     }     return 'Do NOT click the button: ';   }    render() {     return (       <div>         {this.instructions}         <Button onClick={createAlertBox} />       </div>     );   } }

和前面的例子相反,createAlertBox 在每次渲染中仍然有着有相同的引用,因此按钮就不会重新渲染了。

虽然 Button 是一个小型,快速渲染的组件,但你可能会在大型,复杂,渲染速度慢的组件上看到这些内联定义,它可能会让你的 React  应用程序陷入囧境,所以***不要在 render 方法中定义这些函数。

如果函数确实依赖于组件,以至于无法在组件外部定义它,你可以将组件的方法作为事件处理传递过去:

class SomeComponent extends React.PureComponent {    createAlertBox = () => {     alert(this.props.message);   };    get instructions() {     if (this.props.do) {       return 'Click the button: ';     }     return 'Do NOT click the button: ';   }    render() {     return (       <div>         {this.instructions}         <Button onClick={this.createAlertBox} />       </div>     );   } }

在这种情况下,SomeComponent 的每个实例都有一个不同的警告框。 Button 的click事件侦听器需要独立于 SomeComponent。  通过传递 createAlertBox 方法,它就和 SomeComponent 重新渲染无关了,甚至和 message  这个属性是否修改也没有关系。createAlertBox 内存中的地址不会改变,这意味着 Button  不需要重新渲染,节省了处理时间并提高了应用程序的渲染速度

但如果函数是动态的呢?

修复(高级)

这里有个非常常见的使用情况,在简单的组件里面,有很多独立的动态事件监听器,例如在遍历数组的时候:

class SomeComponent extends React.PureComponent {   render() {     return (       <ul>         {this.props.list.map(listItem =>           <li key={listItem.text}>             <Button onClick={() => alert(listItem.text)} />           </li>         )}       </ul>     );   } }

在本例中,有一个可变数量的按钮,生成一个可变数量的事件监听器,每个监听器都有一个独特的函数,在创建 SomeComponent  时不可能知道它是什么。怎样才能解决这个难题呢?

输入记忆,或者简单地称为缓存。 对于每个唯一值,创建并缓存一个函数; 对于将来对该唯一值的所有引用,返回先前缓存的函数。

这就是我将如何实现上面的示例。

class SomeComponent extends React.PureComponent {   // SomeComponent的每个实例都有一个单击处理程序缓存,这些处理程序是惟一的。    clickHandlers = {};    // 在给定唯一标识符的情况下生成或返回单击处理程序。   getClickHandler(key) {     // 如果不存在此唯一标识符的单击处理程序,则创建     if (!Object.prototype.hasOwnProperty.call(this.clickHandlers, key)) {       this.clickHandlers[key] = () => alert(key);     }     return this.clickHandlers[key];   }   render() {     return (       <ul>         {this.props.list.map(listItem =>           <li key={listItem.text}>             <Button onClick={this.getClickHandler(listItem.text)} />           </li>         )}       </ul>     );   } }

数组中的每一项都通过 getClickHandler  方法传递。所述方法将在***次使用值调用它时创建该值的唯一函数,然后返回该函数。以后对该方法的所有调用都不会创建一个新函数;相反,它将返回对先前在内存中创建的函数的引用。

因此,重新渲染 SomeComponent 不会导致按钮重新渲染。类似地,相似的,在 list 里面添加项也会为按钮动态地创建事件监听器。

当多个处理程序由多个变量确定时,可能需要使用自己的聪明才智为每个处理程序生成唯一标识符,但是在遍历里面,没有比每个 jsX 对象生成的 key  更简单得了。

这里使用 index 作为唯一标识会有个警告:如果列表更改顺序或删除项目,可能会得到错误的结果。

当数组从 ['soda','pizza'] 更改为 ['pizza'] 并且已经缓存了事件监听器为 listeners[0] = () =>  alert('soda') ,您会发现 用户点击提醒苏打水的披萨的now-index-0按钮。 但点击 index 为 0 的按钮 pizza  的时候,它将会弹出 soda。这也是 React 建议不要使用数组的索引作为 key 的原因。

到此,关于“JavaScript通过缓存React事件来提高性能”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: JavaScript通过缓存React事件来提高性能

本文链接: https://www.lsjlt.com/news/79592.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript通过缓存React事件来提高性能
    这篇文章主要介绍“JavaScript通过缓存React事件来提高性能”,在日常操作中,相信很多人在JavaScript通过缓存React事件来提高性能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操...
    99+
    2022-10-19
  • 如何通过Git缓存和Load来提高Java应用程序的性能?
    Git是一款非常流行的版本控制工具,它可以用于管理代码、文本文件等等。除了基本的版本控制功能之外,Git还提供了一些高级功能,如缓存和Load。这些功能可以帮助我们提高Java应用程序的性能。在本文中,我们将介绍如何使用Git缓存和Loa...
    99+
    2023-06-05
    git 缓存 load
  • ASP缓存和Django函数:如何通过缓存来提高您的Web应用程序的性能?
    Web应用程序的性能是用户体验的关键因素之一。为了提供更快的响应时间和更好的用户体验,开发人员经常使用缓存技术来减少数据库查询和其他计算量。在本文中,我们将探讨ASP缓存和Django函数如何通过缓存来提高Web应用程序的性能。 ASP缓...
    99+
    2023-06-15
    缓存 django 函数
  • 如何在JavaScript中使用缓存来提高网站性能?
    在当今的互联网时代,网站性能是一个至关重要的因素,因为用户对于快速的响应和流畅的体验有着越来越高的要求。而缓存技术则是提高网站性能的重要手段之一。本文将介绍如何在JavaScript中使用缓存来提高网站性能。 一、什么是缓存? 缓存是一种临...
    99+
    2023-06-29
    缓存 javascript 面试
  • 如何通过PHP开发缓存提高网站的可靠性
    如何通过PHP开发缓存提高网站的可靠性缓存是一种在网站开发中十分重要的技术,通过缓存可以提高网站的访问速度和可靠性。在PHP开发中,我们可以使用不同的缓存技术来提高网站的性能。本文将介绍如何通过PHP开发缓存来提高网站的可靠性,并给出具体的...
    99+
    2023-11-07
    缓存 PHP 可靠性
  • 如何通过PHP开发缓存提高网站的稳定性
    随着互联网的飞速发展,越来越多的网站日益壮大,但同时也带来了一些问题。其中,网站的稳定性成为一个重要的挑战。为了提升网站的稳定性,可以使用缓存技术。本文将介绍如何通过PHP开发缓存来提高网站的稳定性,并提供具体的代码示例。一、什么是缓存技术...
    99+
    2023-11-07
    PHP缓存 开发技巧 网站稳定性
  • 如何使用 PHP 缓存来提高网站性能?
    随着互联网的不断发展,网站性能越来越受到关注。其中,缓存技术是提高网站性能的重要手段之一。在 PHP 中,我们可以使用缓存来减少数据库查询和文件读写操作,从而提高网站的响应速度和并发性能。本文将介绍如何使用 PHP 缓存来提高网站性能,并且...
    99+
    2023-10-04
    缓存 npm git
  • 如何使用Java存储来提高Bash缓存的性能?
    Bash是一种流行的Unix shell,用于在Unix和Linux系统上执行命令。在Bash中,缓存被广泛使用来提高命令执行的速度。然而,在一些情况下,Bash的缓存性能可能会遇到瓶颈。本文将介绍如何使用Java存储来提高Bash缓存的性...
    99+
    2023-10-18
    存储 bash 缓存
  • PHP缓存和JavaScript实时:如何提高网站性能?
    网站的性能是一个关键因素,它直接影响着用户体验和SEO排名。随着网站规模的不断扩大,如何提高网站的性能成为了一个需要解决的问题。本文将介绍如何通过使用PHP缓存和JavaScript实时技术来提高网站性能。 一、PHP缓存 PHP缓存是一...
    99+
    2023-09-23
    缓存 javascript 实时
  • 如何通过PHP开发缓存提高网站的可维护性
    如何通过PHP开发缓存提高网站的可维护性PHP是一种事实上的、被广泛应用的Web开发语言,其灵活性是其优势之一,但也因此可能导致一些性能上的问题。其中之一就是由于每次访问都需要重新计算内容而导致的速度下降。为了提高网站的性能,我们可以使用缓...
    99+
    2023-11-08
    缓存 PHP开发 可维护性
  • 如何使用 ASP IDE 缓存来提高网站性能?
    ASP IDE 缓存是一种强大的工具,可以帮助我们提高网站性能。在这篇文章中,我们将讨论如何使用 ASP IDE 缓存来优化网站性能。 什么是 ASP IDE 缓存? ASP IDE 缓存是一种用于存储和管理 ASP 网站数据的技术。它可以...
    99+
    2023-06-09
    ide 响应 缓存
  • PHP缓存教程:如何使用NPM来提高性能?
    随着网站访问量的增加,PHP的性能问题越来越明显,这时候,缓存就成为了提高性能的重要手段之一。本篇文章将会介绍如何使用NPM来进行PHP缓存,从而提高网站的性能。 一、什么是PHP缓存? PHP缓存是指将PHP脚本的编译结果保存在内存中,...
    99+
    2023-07-25
    缓存 教程 npm
  • 如何通过PHP开发缓存提高网站的响应能力
    如何通过PHP开发缓存提高网站的响应能力随着互联网的快速发展,网站的访问量越来越大,这给网站的性能和响应能力提出了更高的要求。缓存是一种提高网站响应能力的重要技术之一。本文将介绍如何通过PHP开发缓存来提高网站的响应能力,并给出具体的代码示...
    99+
    2023-11-07
    PHP缓存 网站性能 响应能力
  • PHP缓存和JavaScript容器:是否可以提高网站性能?
    在现代互联网应用程序的开发中,性能是至关重要的因素。每个网站都希望快速响应用户请求,减少加载时间并提高用户体验。一种常见的解决方案是使用缓存技术来减少服务器的负载并提高性能。PHP缓存和JavaScript容器是两种常见的缓存技术,本文将...
    99+
    2023-06-16
    缓存 javascript 容器
  • Javaservlet通过事件驱动进行高性能长轮询详解
    目录servlet3.0的异步原理使用servlet3.0实现长轮询长轮询实现servlet3.0的异步原理 servlet基础就不做介绍了,这里就介绍servlet3.0的一个重要...
    99+
    2022-11-13
  • 如何使用 PHP 缓存 NumPy 实时来提高网站性能?
    随着互联网的快速发展,网站的性能问题愈发显著,尤其是对于那些需要大量计算的网站,如数据分析、机器学习等,更是如此。这些网站需要处理大量的数据,而且需要在实时性要求较高的情况下进行计算。在这种情况下,缓存技术是一个非常有效的解决方案。 在本...
    99+
    2023-10-03
    缓存 numy 实时
  • Python 中的文件缓存对象:如何调整缓存大小以提高性能?
    在 Python 中,文件缓存对象是一个非常有用的工具,它可以提高文件读写的性能。默认情况下,Python 会将文件读取到内存中的缓存中,并且会尽可能地将缓存的大小调整到最佳状态。但是,在某些情况下,缓存大小可能会对性能造成影响,因此我们...
    99+
    2023-07-11
    文件 缓存 对象
  • 如何通过本地加载ga.js文件提高Google Anlytics性能
    如何通过本地加载ga.js文件提高Google Anlytics性能,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Google分析代码到底会不会影响网页性能?本地托管ga.js...
    99+
    2023-06-12
  • Laravel 和 Bash:如何通过它们来提高 Web 应用的性能?
    随着 Web 应用的不断发展,对性能的要求也越来越高。为了提高 Web 应用的性能,我们可以使用 Laravel 和 Bash 这两个工具。Laravel 是一个流行的 PHP Web 应用框架,而 Bash 是一个 Unix shell...
    99+
    2023-06-14
    numpy laravel bash
  • Java中如何使用缓存来提高数组的并发性能?
    在Java中,数组是一种常用的数据结构,它在很多场景下都被广泛使用。然而,在多线程并发的情况下,数组的性能可能会受到很大的影响,因为多个线程同时对同一个数组进行读写操作时,可能会发生数据竞争,导致数据错误或性能下降。为了解决这个问题,我们...
    99+
    2023-07-07
    缓存 数组 并发
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作