在现代的JavaScript项目管理中,pnpm
是一个备受欢迎的包管理器,它提供了一种称为“过滤”的强大功能,允许开发者限制命令执行到特定的包子集。这篇教程将详细介绍如何使用pnpm
的过滤功能来提高你的开发效率。
基本用法
过滤器可以通过--filter
(或简写-F
)标志来指定,其基本语法如下:
pnpm --filter <package_selector> <command>
精确匹配包
如果你想对特定的包执行命令,可以直接指定包的名称:
pnpm --filter "@babel/core" test
这将只对@babel/core
包执行test
命令。你也可以使用通配符来匹配一组包:
pnpm --filter "@babel/*" test
选择包及其依赖
要选择一个包及其所有依赖(直接和间接),在包名后添加省略号:
pnpm --filter "foo..." test
这将对foo
包及其所有依赖执行test
命令。
选择包的依赖
如果你只想选择某个包的依赖项,而不包括该包本身,可以使用^
符号:
pnpm --filter "foo^..." test
选择依赖特定包的包
要选择依赖特定包的所有包,可以在包名前添加省略号:
pnpm --filter "...foo" test
排除特定包
过滤器也支持排除特定包的功能,只需在包名前添加!
符号:
pnpm --filter "!foo" test
在某些shell中,可能需要转义!
符号。
使用glob模式
过滤器支持使用glob模式来匹配工作目录中的项目:
pnpm --filter "./packages/**" test
这将包括指定目录下的所有项目。
结合since使用
过滤器可以与[<since>]
结合使用,来选择自特定提交或分支以来有更改的所有包:
pnpm --filter "...[origin/master]" test
忽略特定模式的文件
当使用changed since
过滤器时,可以通过--changed-files-ignore-pattern
来忽略特定模式的文件:
pnpm --filter "...[origin/master]" --changed-files-ignore-pattern "**/README.md" run build
通过这些高级过滤选项,pnpm
为开发者提供了灵活的方式来管理和执行对包的操作。无论是在大型的mono-repo项目中,还是在需要精确控制的场景下,pnpm
的过滤功能都能显著提升你的工作流程。