npm 包 @erquhart/lerna-filter-packages 使用教程

前言

在开发复杂的前端项目时,我们通常会使用 Lerna 来管理多个相关的 npm 包。Lerna 提供了方便的工具来管理这些包之间的依赖关系,同时也提供了一些 CLI 命令来方便地运行多个包的相应操作。其中一个重要的命令是 lerna exec,这个命令可以在 Lerna 项目中的每个包中运行任意命令。

但是,在某些情况下,我们希望只在部分包中运行命令,而不是整个项目中的每个包中都运行。这时,一个叫做 @erquhart/lerna-filter-packages 的 npm 包就派上用场了。

什么是 @erquhart/lerna-filter-packages?

@erquhart/lerna-filter-packages 是一个 Lerna CLI 插件,用于筛选特定的包。它会扫描 Lerna 项目中的所有包,并根据指定的规则过滤出匹配的包,以便在这些包中运行相应的命令。

如何使用 @erquhart/lerna-filter-packages?

安装

首先,需要安装 @erquhart/lerna-filter-packages。可以使用以下命令进行安装:

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

用法

使用方法很简单。在运行 lerna exec 命令时,需要添加以下选项:

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

其中,<pattern> 是用来匹配包的模式,<command> 是需要在匹配的包中运行的命令。

例如,如果希望在所有名称以“my-package”开头的包中运行命令 npm test,可以使用以下命令:

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

这将会在 my-package-1my-package-2 等名称以 “my-package” 开头的包中运行 npm test 命令。

高级用法

除了使用基本的模式匹配外,还可以使用更高级的过滤规则。具体来说,可以使用以下三种过滤器:

  1. 包含过滤器

使用 ~ 符号来将过滤器作为包名称的一部分。例如,需要匹配所有包含“my-package”的名称:

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

这将会匹配 my-package-1your-my-package 等名称中包含 “my-package” 的包。

  1. 排除过滤器

使用 ! 符号将过滤器排除在匹配范围之外。例如,需要在所有不以“my-package-1”开头的包中运行命令 npm test

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

这将会匹配 my-package-2your-my-package 等所有不以 “my-package-1” 开头的包。

  1. 正则表达式过滤器

使用 / 符号将过滤器解释为正则表达式。例如,需要匹配所有名称以数字结尾的包:

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

这将匹配 my-package-1your-package-2 等所有名称以数字结尾的包。

示例代码

以下是一个示例代码,用于演示如何使用 @erquhart/lerna-filter-packages 在指定的包中运行命令:

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

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

结论

@erquhart/lerna-filter-packages 是一个非常有用的工具,可以帮助我们在 Lerna 项目中更精确地运行命令。无论是在调试、测试还是部署阶段使用,@erquhart/lerna-filter-packages 都可以使我们的工作更加高效和便利。

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


猜你喜欢

  • npm 包 victory-voronoi-container 使用教程

    介绍 victory-voronoi-container 是一个基于 d3-voronoi 和 VictoryChart 的 npm 包,用于将数据可视化成蜂窝状的图形。

    4 年前
  • npm 包 vega-transforms 使用教程

    前言 在开发前端应用过程中,数据可视化是一个重要的领域。而 vega-transforms 是一个非常优秀的数据转换库。通过使用 vega-transforms,我们可以很方便地完成各种复杂的数据转换...

    4 年前
  • npm 包 victory-zoom-container 使用教程

    Victory 是一个用于数据可视化的 JavaScript 库。其中,victory-zoom-container 是其中的一个用于缩放的插件,可以用于通过拖动或滚轮缩放图表或子组件。

    4 年前
  • npm 包 vega-format 使用教程

    在前端开发中,我们常常需要将数据可视化,而 Vega 是一个用于生成交互式图表和视觉化界面的语言和工具,而 vega-format 是一个将数据格式化为 Vega 数据格式的 npm 包。

    4 年前
  • npm 包 vega-loader 使用教程

    简介 vega-loader 是一个 JavaScript 库,用于将 Vega 和 Vega-Lite 规范的 JSON 数据加载到浏览器中。该库配合 Vega 和 Vega-Lite 库使用,可以...

    4 年前
  • npm 包 victory-polar-axis 使用教程

    在 Web 开发中,绘制图表以展现数据非常常见。而 React 技术栈下,Victory 是一个非常优秀的图表库。其中,victory-polar-axis 是 Victory 库下的一个 npm 包...

    4 年前
  • npm 包 lade 使用教程

    概述 lade 是一个基于 webpack 的前端构建工具,旨在对项目进行模块化打包,并提供了一些常用的功能模块,例如生成 HTML 模板、压缩代码、资源加载等。 安装 在项目根目录下打开终端,运行以...

    4 年前
  • npm 包 jasmine-def 使用教程

    什么是 npm? npm(Node Package Manager)是一个 Node.js 包管理工具,可以方便地安装、升级、删除、管理开源代码库。npm 包通常是 JavaScript 模块,这些模...

    4 年前
  • NPM 包 gulp-cleancss 使用教程

    前言 gulp-cleancss 是一个用来压缩和优化 CSS 的 NPM 包,其作用是清理和优化 CSS 代码,减小文件大小,提高加载速度。如果你经常使用 gulp 和 CSS,那么这个包会很有用。

    4 年前
  • npm 包 gulp-nginclude 使用教程

    #npm 包 gulp-nginclude 使用教程 概述 在前端开发中,我们经常会碰到需要引用其他页面片段的情况。以前,我们需要手动复制粘贴 html 片段,但是这种方式对于重复的代码来说是极不优雅...

    4 年前
  • npm 包 gulp-ngtemplate 使用教程

    在前端开发中,经常会遇到需要将 HTML 模板文件转化为 JavaScript 文件的情况。这时我们可以使用 gulp-ngtemplate 这个 npm 包来实现自动化处理。

    4 年前
  • npm 包 vue-node 使用教程

    什么是 vue-node vue-node 是一个基于 Vue、Node.js 和 Socket.IO 的实时通讯应用框架。它采用了前后端分离的架构,前端使用了 Vue.js 框架,后端使用了 Nod...

    4 年前
  • npm 包 vue-add-globals 使用教程

    前言 在 Vue.js 框架的开发中,我们有时候需要将某些变量挂载到全局,以便其在 Vue 实例中的所有组件中都能够访问到。这时候,vue-add-globals 这个 npm 包就可以派上用场了。

    4 年前
  • npm 包 cypress-image-snapshot 使用教程

    什么是 cypress-image-snapshot cypress-image-snapshot 是一个 npm 包,它可以让你使用 Cypress 来进行网站截图测试,并提供了一些工具来比较图片,...

    4 年前
  • npm 包 @types/jsonschema 使用教程

    在前端开发中,我们往往需要使用一些 JSON 格式的数据。JSON Schema 是一个用于定义 JSON 数据结构的标准。而在 TypeScript 中,使用 JSON Schema 就可以更加方便...

    4 年前
  • npm 包 @types/karma-fixture 使用教程

    简介 在前端开发中,我们通常会使用 Karma 进行单元测试。而 Karma Fixture 则是针对前端单元测试中的静态资源管理的解决方案,它可以在我们运行单元测试时,自动加载测试用例所需的静态资源...

    4 年前
  • npm 包 array-findindex-polyfill 使用教程

    在前端开发中经常需要对数组进行处理,而 ES6 中提供了 Array.findIndex() 方法来查找数组元素,但是在一些老旧浏览器中并不支持该方法。为了解决这个问题,可以使用 array-find...

    4 年前
  • npm 包 project-name-generator 使用教程

    前言 当我们在开发一个新的项目时,往往需要给它起一个好听的,有意义的项目名字。有时候我们可能会因为创意枯竭或者取名过于随意而导致项目名并不太满意。这时候,我们可以使用 npm 包 project-na...

    4 年前
  • npm 包 bitmap-sdf 使用教程

    介绍 Bitmap-SDF 是一个 JavaScript 库,它可以将位图字形转换为使用基于距离场的技术生成的“距离场” (SDF: Signed Distance Field) 字形。

    4 年前
  • npm 包 is-svg-path 使用教程

    在前端开发中,处理 SVG 图形时经常需要对 SVG path 进行一些操作,例如判断一个 path 是否是一个合法的 SVG path,这时候我们可以使用一个很好用的 npm 包 - is-svg-...

    4 年前

相关推荐

    暂无文章