npm 包 memoize.js 使用教程

随着前端应用的日益复杂,在大量的计算和数据处理中,性能问题越来越成为前端开发者的头号烦恼。优化的一个手段之一就是 memoization(记忆化)。memoization 是一个通过缓存实现性能优化的概念。在函数的计算过程中,我们可以缓存函数的输入和输出结果,这样当下一次输入相同的参数时,我们可以直接从缓存中读取结果,避免重新计算,提高性能。

memoize.js 是一个工具库,专门为 JavaScript 进行 memoization 提供帮助。下面我们将详细介绍如何使用 memoize.js 。

安装

可以通过 npm 安装 memoize.js:

--- - --------

当然你也可以使用 yarn:

---- --- --------

使用

memoize.js 支持对任意函数进行记忆化,记忆化后的函数可以缓存结果,当再次调用时,会直接从缓存中获取结果,而不是再次执行函数。

针对普通函数

针对普通函数的记忆化处理非常简单,只需使用 memoize 函数,将要记忆化的函数作为参数传入即可:

----- ------- - --------------------

-------- ------------ -
  ------ - - - - - - - - ----------- - ---
-

----- ----------------- - -------------------

---------------------------------- -- ---
---------------------------------- -- ---- -----
---------------------------------- -- ---

memoize 函数的第二个参数可以指定一个选项对象,包括了许多相关的选项:

  • maxAge: 缓存的最长时间,单位是毫秒。
  • preFetch: 是否在参数传入时就计算结果而不是在第一次调用时计算。
  • primitive: 是否缓存原始类型的值(number, boolean, string)。
  • async: 是否只针对异步函数使用。
  • normalizer: 缓存键的生成函数,用户可以手动指定。

针对类的方法

针对类的方法的记忆化与普通函数的记忆化类似,只需要特别注意 this 的问题。由于箭头函数没有自己的 this,所以使用箭头函数记忆化类方法非常方便。

----- ------- - --------------------

----- ---------- -
  ------ -- -
    ------------------------------
    ------ - - --
  -
-

----- ---------- - --- -------------
----- ----------- - ----------------------------------------- -- ----- ---- ---

-------------------------- ---- -- -------------- -
-------------------------- ---- -- -- -----
-------------------------- ---- -- -------------- -

使用 ES6 class 定义的函数有一个问题:它们使用了严格模式。在严格模式下,this 不被允许自动转换为全局对象 window。因此,当用记忆化函数装饰某一个函数或方法时,要先将函数或方法 bind 到正确的 this 之上,这样 memoize 才能正常工作。

使用示例

下面我们来实际使用 memoize.js 解决一个经典面试题:斐波那契数列(fibonacci)的 memoization 优化。

----- ------- - --------------------

-------- ------------ -
  -- -- - -- -
    ------ --
  -
  ------ -------------- - ---------------
-

----- ---------------- - -------------------

---------------- ----------
---------------------------
------------------- ---------- -- ------- -- --

------------------ ----------
----------------------------------
--------------------- ---------- -- ------- ---- --

可以看到,通过 memoization,我们成功将执行 fibonacci 函数所需要的时间从几秒缩短为几毫秒。

总结

memoize.js 是一个非常优秀的记忆化库。在需要极致性能的场景下,memoization 是一个不错的选择。memoize.js 的记忆化处理非常简单,而且随着适当的选项配置,非常有弹性。愿此篇文章能帮助你用 memoize.js 记忆化你的前端应用中各种复杂的计算。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/6005570d81e8991b448d3f72


猜你喜欢

  • npm 包 no-undefined-style-loader 使用教程

    前言 在前端开发中,我们经常会遇到一些未定义的样式问题,这时候我们需要去查找代码并修复。为了更好地解决这个问题,我们可以使用 no-undefined-style-loader 这个 npm 包来帮助...

    2 年前
  • npm 包 robin-hood 使用教程

    简介 npm 是一个非常流行的 Node.js 包管理器,可以帮助开发者轻松地管理依赖库。robin-hood 是一个非常实用的 npm 包,可以在 JavaScript 中实现高效的哈希表。

    2 年前
  • npm 包 superfly-css-utilities-fonts 使用教程

    随着前端技术的不断更新,大量的 npm 包也不断涌现。其中有一个 npm 包,名为 superfly-css-utilities-fonts,它是一个 CSS 工具库,专注于为网页提供更加美观的字体样...

    2 年前
  • npm 包 superfly-css-utilities-layout 使用教程

    简介 superfly-css-utilities-layout 是一个方便实用的 CSS 布局工具箱,可快速创建样式组合来满足不同的布局需求。使用该工具箱可以轻松实现响应性和可定制的布局——不需要编...

    2 年前
  • npm 包 generator-tmj-module 使用教程

    前言 在日常的前端开发中,我们经常会自己编写一些复用性很高的代码,然后将这些代码封装成一个 npm 包,方便自己和他人使用。而 generator-tmj-module 就是一个可以帮助我们快速生成 ...

    2 年前
  • NPM包Cerebro-Dash使用教程

    Cerebro-Dash是一款基于React技术的Web应用程序,用于搜索和管理系统内置的快捷命令。它提供支持各种应用程序、网站、API管理等多种功能,并且可以自定义添加命令,是一款功能强大的工具。

    2 年前
  • npm 包 cerebro-word-count 使用教程

    简介 cerebro-word-count 是一款基于 Node.js 平台的命令行工具,用于统计文本文件中单词数量的 npm 包。通过简单的命令行操作,我们可以快速方便地得到文本文件中的单词数量。

    2 年前
  • npm 包 webpack-watch-log-plugin 使用教程

    在开发前端项目过程中,我们通常会使用 webpack 进行打包处理。然而,由于 webpack 打包过程较为复杂,如果出现问题,我们可能不知道出现了哪些错误,特别是当我们的文件很多时,我们很难追踪日志...

    2 年前
  • npm包knexjs-dump-man使用教程

    简介 在前端开发中,经常需要使用数据库来存储和管理数据。而Knexjs是一款非常流行、易用且功能强大的JavaScript SQL查询构建器。但是,对于初学者来说,使用Knexjs所生成的SQL语句并...

    2 年前
  • npm 包 fanutils 使用教程

    简介 fanutils 是一个常用的 JavaScript 工具库,包含了常见的数据处理、时间格式化、浏览器判断、字符串处理等等方法。 它存放在 npm 官方仓库中,可以使用 npm 工具下载到本地,...

    2 年前
  • npm 包 grunt-svgbg 使用教程

    前言 在前端开发过程中,有时需要使用到 SVG 图标,最常见的方法就是用 img 标签来引用图标文件。但是这种做法会导致页面请求过多,影响性能。为了解决这个问题,可以使用 grunt-svgbg 这个...

    2 年前
  • npm 包 generator-next-playground 使用教程

    前言 在前端开发中,我们常常需要创建一个新的项目,然后进行一系列的配置和初始化工作。这个过程往往需要耗费很长时间,而且容易出现一些问题。 为了解决这个问题,许多前端开发者开始使用一些工具来快速搭建项目...

    2 年前
  • npm 包 raininfall.redux-perf-middleware 使用教程

    在现代的前端开发中,Redux 已经成为了一个非常流行的数据状态管理工具。它的使用使得我们可以更轻松地组织和管理应用程序的业务逻辑。但是,Redux 本身并没有提供性能监控的功能,这就需要我们使用第三...

    2 年前
  • npm 包 babel-plugin-transform-eliminate-dead-conditionals 使用教程

    前言 前端开发中,我们经常会使用一些工具来帮助我们持续优化代码的质量和性能。而 babel-plugin-transform-eliminate-dead-conditionals 就是其中一个在前端...

    2 年前
  • NPM 包 colours-in-culture 使用教程

    介绍 在前端开发中,颜色选择一直是一个重要的工作。不同颜色在不同的文化背景下有着截然不同的含义,因此,在设计和开发中可能会遇到一些文化差异的问题。为了解决这个问题,我们需要一个能够帮助我们匹配正确的颜...

    2 年前
  • npm包ilsp-ng2-grid使用教程

    在前端开发中,经常需要使用表格组件,而ilsp-ng2-grid是一个易用且功能强大的npm包,它可帮助我们快速地创建灵活的,可定制的表格。本文将详细介绍该包的使用教程,并提供示例代码。

    2 年前
  • npm 包 tslint-config-leomax 使用教程

    前言 在开发前端项目时,为了提高代码的质量和可维护性,我们常常会使用 linter 工具。而 tslint 是一款专门用于检查 TypeScript 代码的 linter 工具。

    2 年前
  • npm 包 ng2-img-cropper-custom 使用教程

    1. npm 包 ng2-img-cropper-custom 简介 npm 包 ng2-img-cropper-custom 是一个能够在 Angular 应用中实现图片裁剪的插件。

    2 年前
  • npm包react-maskedinput-maxwell使用教程

    本文为大家介绍一款基于React框架的npm包——react-maskedinput-maxwell。该npm包是一款用于输入框掩码格式化的组件库,在前端开发中有着广泛的应用。

    2 年前
  • npm 包 vbl-side-bar-tab 使用教程

    vbl-side-bar-tab 是一个用于在网站侧边栏中创建标签页的 npm 包。本文将向你展示如何安装和使用它。 安装 首先,你需要在你的项目中安装该npm包,可以通过 npm 安装: --- -...

    2 年前

相关推荐

    暂无文章