npm 一些有用的提示和技巧
生成 package.json
我们通常执行 npm init
,然后开始添加 npm 请求的信息。 但是,如果我们不关心所有这些信息,并且希望保留默认值,那么对于 npm 请求的每一条数据,我们都按 enter 键。为了避免这种情况,你可以输入 npm init -y
。这样就可以跳过问题询问了。
注:你也可以使用 npm init --yes
作用是一样的。
安装模块
你可以使用更加简单的 npm i
来代替 npm install
。
一次安装多个模块
你不需要为每个模块键入一个 npm install
命令,例如:
npm i gulp-pug
npm i gulp-debug
npm i gulp-sass
你可以只运行一个命令,一次性安装所有这些模块:
npm i gulp-pug gulp-debug gulp-sass
还有更加简单的方法,如果所有名称都以相同的前缀开头,你不需要键入整个名称:
npm i gulp{-debug,-sass,-pug}
使用 install flags(安装参数) 的快捷方式
如果要安装软件包并将其另存为生产依赖项,则通常会这样做
npm i gulp --save-prod
你可以使用 -P
快捷方式,像这样:
npm i gulp -P
对于开发依赖项也是一样,不需要键入完整的 --save-dev
标志,你可以使用 -D
快捷方式,像这样:
npm i gulp -D
默认情况下,当你运行不带任何 flags(参数) 的 npm install
时,npm 会将包作为依赖项添加到 package.json
文件中。 如果要防止这种情况,请使用 --no-save
flags(参数) 安装,如下所示:
npm i gulp --no-save
获取包信息
下面的命令将显示 vue 包的相关信息:
npm view vue
或 npm v vue
如果你只想获得最新版本的软件包,可以试试下面这个命令:
> npm v vue version
> 2.5.17
如果你想获得 npm 包完整的版本列表,请尝试复数形式

> npm v vue versions
> [ '0.0.0',
'0.6.0',
'0.7.0',
...
'2.5.15',
'2.5.16',
'2.5.17-beta.0',
'2.5.17' ]

安装特定版本的软件包
如果要安装版本,而不是最新版本的软件包,可以键入:
npm i vue@2.5.15
鉴于记忆名称比数字更容易(至少对我来说),你可以使用 dist-tag 列表中名称,运行 npm v
命令即可得到该列表 ,如下所示:
npm i vue@beta
搜索 package(包)
有时你可能记不住你前一段时间或你朋友推荐的某个 package(包) 的确切名称。 在这种情况下,你可以使用 npm 搜索,直接在终端中执行搜索:
npm search gulp debug
或者
npm s gulp debug
这将打印包含描述,作者和一些其他信息的包列表:
卸载 package(包)
如果你不想打开 package.json 文件并从那里手动删除依赖项,则可以使用以下命令将其删除:
npm uninstall vue
这将从 node_modules
文件夹和 package.json
文件中删除该包。 当然,你可以使用 rm
, un
或 r
来实现相同的效果,例如:
npm rm vue
如果由于某种原因你只想从 node_modules
文件夹中删除包文件,但仍然将其作为依赖项保存在 package.json
文件中,则可以使用 --no-save
参数:
npm rm vue --no-save
列出依赖项
如果要查看项目依赖项列表,可以使用
npm ls
这将列出 package.json
文件中所有的依赖项以及它们的所有依赖项。 如果你只想列出你的依赖项,你可以这样做
npm ls --depth=0
这将打印出这样的东西:
├── jquery@3.3.1
├── vue@2.5.17
└── yarn@1.12.3
当然,如果要查看所有全局安装的包的列表,可以使用 -g
标志
npm ls -g -depth 0
运行测试
你可以使用 npm run tests
运行测试,但你可以用 npm test
甚至更简短的 npm t
代替。
显示可用的 script
有时,我们希望查看 package.json
文件中包含的脚本。 我们当然可以打开 package.json
文件,但我们也可以这样做:
npm run
如果在 package.json
文件中有这样的配置,如下所示:
"scripts": {
"test": "jest",
"build": "gulp build"
}
那么 npm run
命令将显示以下内容:

Lifecycle scripts included in npm:
test
jest
available via `npm run-script`:
build
gulp-build

从 Github 仓库安装 package(包)
你可以直接从 Github 仓库安装一个包:
npm i https://github.com/sindresorhus/gulp-debug
或者你可以省略域名部分
npm i sindresorhus/gulp-debug
打开包的 Github 页面
你当然可以通过 Google 搜索,然后查找该页面,或者你可以执行以下操作:
npm repo create-react-app
无需安装软件包即可执行上述命令。
列出所有可用的 NPM 环境变量
你可以通过运行以下命令来查看可供我们使用的 NPM 变量的完整列表:
npm run env | grep npm_
上面的命令将打印如下内容:
npm_config_fetch_retry_maxtimeout=60000
npm_config_tag_version_prefix=v
npm_config_strict_ssl=true
npm_config_sso_type=oauth
这些变量的好处是它们可以在你的脚本中使用,你甚至可以创建自己的 NPM 环境变量,让我们看看如何创建。
添加自己的 NPM 变量
你可以通过向 package.json
文件添加自己的 NPM 变量。 它可以是任何 key,但我更喜欢将所有 NPM 变量放在 config
key 中,以保持结构有序。 像这样:
"config": { "build_folder":"./dist" }
现在,如果你使用前面讨论的命令 npm run env | grep npm_
列出你的变量,你会看到你的新变量在那里:
npm_package_config_build_folder=./dist
npm_config_fetch_retry_maxtimeout=60000
npm_config_tag_version_prefix=v
npm_config_strict_ssl=true
npm_config_sso_type=oauth
默认情况下,npm 会将你的变量命名以 npm_package
为前缀,并保持其在 package.json文件中的结构,即 config_build_folder
。
在 NPM script 中使用 NPM 变量
一旦你看到了完整的变量列表,并且你希望在 script 中使用这些变量中的任何一个的值,那么你就可以在 package.json 中执行此操作(请参阅上一节中变量 npm_package_config_build_folder
的值)
"scripts": {
"build": "gulp build --dist $npm_package_config_build_folder"
}
一旦你用 npm run build
运行这个命令,它将被执行为
gulp build --dist ./dist
npm 一些有用的提示和技巧的更多相关文章
- Web 开发中 9 个有用的提示和技巧
在本文中,我们给出 9 个有用的 HTML.CSS 和 JavaScript 的技巧和提示,可能在做 Web 开发中经常会需要用到的,其中有几个是关于 HTML5 和 CSS3 的,如果你是一个前端开 ...
- 开发中可能会用到的几个 jQuery 小提示和技巧
今天,我们将分享一些很有用的技巧和窍门给 jQuery 开发人员.jQuery 是最好的 JavaScript 库之一,用于简化动画,事件处理,支持 Ajax 和 HTML 的客户端脚本.网络中有大量 ...
- 25个增强iOS应用程序性能的提示和技巧(高级篇)(2)
25个增强iOS应用程序性能的提示和技巧(高级篇)(2) 2013-04-16 14:56 破船之家 beyondvincent 字号:T | T 在开发iOS应用程序时,让程序具有良好的性能是非常关 ...
- 25个增强iOS应用程序性能的提示和技巧(中级篇)(3)
25个增强iOS应用程序性能的提示和技巧(中级篇)(3) 2013-04-16 14:42 破船之家 beyondvincent 字号:T | T 本文收集了25个关于可以提升程序性能的提示和技巧,分 ...
- 25个增强iOS应用程序性能的提示和技巧--中级篇
25个增强iOS应用程序性能的提示和技巧--中级篇 标签: ios性能优化内存管理 2013-12-13 10:55 738人阅读 评论(0) 收藏 举报 分类: IPhone开发高级系列(34) ...
- 25个增强iOS应用程序性能的提示和技巧(初级篇)
25个增强iOS应用程序性能的提示和技巧(初级篇) 标签: ios内存管理性能优化 2013-12-13 10:53 916人阅读 评论(0) 收藏 举报 分类: IPhone开发高级系列(34) ...
- 增强iOS应用程序性能的提示和技巧(25个)
转自 http://www.cocoachina.com/newbie/basic/2013/0522/6259.html 在开发iOS应用程序时,让程序具有良好的性能是非常关键的.这也是用户所期望的 ...
- (转)25个增强iOS应用程序性能的提示和技巧--初级篇
在开发iOS应用程序时,让程序具有良好的性能是非常关键的.这也是用户所期望的,如果你的程序运行迟钝或缓慢,会招致用户的差评.然而由于iOS设备的局限性,有时候要想获得良好的性能,是很困难的.在开发过程 ...
- 几个 jQuery 小提示和技巧
几个 jQuery 小提示和技巧 今天,我们将分享一些很有用的技巧和窍门给 jQuery 开发人员.jQuery 是最好的 JavaScript 库之一,用于简化动画,事件处理,支持 Ajax 和 H ...
随机推荐
- python 基础学习笔记(2)---字符串功能函数
**上一篇写到了,基本的数据类型,今天重点来讲一下字符串的功能函数**回顾一下上篇的内容:一.int 整型,在python 3 中与long型合并 可以达到 -9223372036854775808- ...
- kubernetes实战篇之docker镜像的打包与加载
系列目录 前面我们讲到了使用nexus搭建docker镜像仓库,操作还是有点复杂的,可能有的童鞋仅仅是想尝试kubernetes功能,并不想在搭建仓库上花费过多时间,但是又想在不同的主机之间传递镜像. ...
- Mybatis 一对多分页踩坑 对collection的分析
背景描述: 产品和结算对象(结算名和结算金额)是一对多的关系,使用 collection 做一对多配置.但是出现一对多时,数据没有整合至一起,导致一个产品重复出现. class ResponseVo{ ...
- C++20 的 Modules
最近看了两篇关于 C++ 20 Modules 很有意思的文章,戳: <Understanding C++ Modules: Part 1: Hello Modules, and Module ...
- 利用Jmeter模拟Github登录
最近学习了Jmeter的简单操作,很想找点东西来实战一下,因为我之前写过一篇通过Python模拟登录的文章,于是便想尝试下学习通过Jmeter来模拟登录. 本人环境:Jmeter5.1.1 关于Git ...
- 从无到有构建vue实战项目(五)
八.错误总结(一) webpack打包项目识别子组件路径问题 之所以出现了这样的问题是因为在webpack打包项目时,未将此处的子组件路径正确识别: 将此处的carousel改为carousel.vu ...
- Spring WebFlux之HttpHandler的探索
这是本人正在写的<Java 编程方法论:响应式Reactor3.Reactor-Netty和Spring WebFlux>一书的文章节选,它是<Java编程方法论:响应式RxJava ...
- [转载]nginx负载均衡+keepalived三主(多主)配置
nginx负载均衡+keepalived三主(多主)配置 1.实验环境,实现目标三台主机分别配置nginx负载均衡对后端多台主机做转发,同时配置keepalived实现HA,保证任意主机出现故障时其他 ...
- SpringBoot集成beetl模板快速入门
SpringBoot集成beetl模板快速入门 首次探索 beetl官方网址:http://ibeetl.com/ 创建SpringBoot工程(idea) 新建工程 选择创建Spring工程 书写包 ...
- DataNode的工作机制
DataNode的工作机制 一个数据块在DataNode以文件的形式在磁盘上保存,分为两个文件,一个是数据本身, 一个是元数据信息(包括数据的长度,校验和,时间戳) 1.DataNode启动后,向Na ...