npm有个命令突破我知识认知了

简介: npm是一个包管理工具,当我们安装nodejs时,这个命令会默认安装。你可能非常熟悉npm run xxx这个命令,每次上线前你都在执行npm run build,甚至你常常在npm i的等待中摸鱼。

npm是一个包管理工具,当我们安装nodejs时,这个命令会默认安装。你可能非常熟悉npm run xxx这个命令,每次上线前你都在执行npm run build,甚至你常常在npm i的等待中摸鱼。


当某一天你的同事在你电脑输入了一行命令...,npm view typescript versions,你脑壳里想着,这

a658af20794d9f49640f901127dd2ab2.jpg

于是乎,你去官方文档查了下这个命令,原来npm view xx versions是查询 xx 包所有可用版本。为了不拘泥于npm run startnpm run build这两行命令,于是笔者总结了这篇很深度,很广度的npm命令大全,希望你能在你实际项目中能用得上。


正文开始...


npm init


npm init
// or npm init -y

该命令意思是初始化一个包项目,生成一个package.json文件

ecda5ae5dca096f06e7e642a3ad4ae3d.jpg

可以一直enter键下去,你也可以按你心情在控制台输入一些信息,然后enter下去later...

2951cad3ce307e45964cb83fd8a44a1a.png

最后在你目录下生成了一个package.json文件

{
  "name": "npm-know",
  "version": "1.0.0",
  "description": "My first encounter with npm",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [
    "npm"
  ],
  "author": "Maic",
  "license": "ISC", // 以上都是默认的配置
}

另外如果你想在指定的目录中生成package.json,那么你你只需执行下面一行命令npm init -w 01, 01是你当前已存在的目录,如果01不存在,则会在你得根目录.Trash中创建一个01/package.json


关于package.json的一些解释
// name  包名,如果你需要发布一个npm包,那么这是必须的
// version 版本 同上,你需要发布一个包,那么版本是必须的 包名+版本构成一个包的唯一标识
// description 包名的描述,npm能根据这个描述检索你得包名
// main 程序的主要入口,默认index.js
// scripts 可以执行npm 指定运行的别名
// keywords 关键字,便于别人搜索关联找到你发布的包名
// author 发布该包的作者名
// license 许可证 通常是ISC或者MIT,便于开发者知道这是个开源可免费试用的包

关于package.json的默认的配置就是这么多,接下来,你感兴趣的来了,她来了,她就是bin...

{
  ...,
  license: 'ISC',
   "bin": {
     "maic-app-cli": "./cli.js"
   }
}

在官方解释这个bin有点绕,我的理解的就是,提供一个可执行的接口命令,让你可以运行你写的包,能关联到当前的项目,不管是全局还是局部安装,npm可以通过这个bin的别名命令,执行指定包内的脚本,从而进行一系列的初始化工作。比如大名鼎鼎的vue-clicreate-react-app脚手架,当你看到vue-cli@2.96版本package.json时,可以看到vue命令的操作

{
  "name": "vue-cli",
  "version": "2.9.6",
  "description": "A simple CLI for scaffolding Vue.js projects.",
  "preferGlobal": true,
  "bin": {
    "vue": "bin/vue",
    "vue-init": "bin/vue-init",
    "vue-list": "bin/vue-list"
  },
  ...
}

前往bin/vue目录你可以看到

#!/usr/bin/env node
const program = require('commander')
program
  .version(require('../package').version)
  .usage('<command> [options]')
  .command('init', 'generate a new project from a template')
  .command('list', 'list available official templates')
  .command('build', 'prototype a new project')
  .command('create', '(for v3 warning only)')
program.parse(process.argv)

这里就是熟悉的脚手架vue create xx,vue init的一些 xxx项目的脚手架工作了,具体可以查看vue-cli 源码[1]


关于bin的实际操作,后续会专门写一个自己的脚手架,再来细细了解下这些知识。

conig,这个配置可以在你指定包名,版本升级时,一些特殊值可以保持不变。


dependencies这是一个开发依赖,当你在你得cmd控制台输入npm i ramda -s

2c1ac513d502b7c91ce5727161e80c10.jpg

package.jsondependencies生成了一个依赖文件"ramda": "^0.27.1"

devDependencies是一个在生产环境需要依赖的包,dependenciesdevDependencies的区别是:npm i xx -snpm i xx --save-dev,在实际项目开发中,你可以把dependencies安装的开发环境依赖包,在你打包的时候利用webpackexternals外部扩展特性分离出去,也就是将开发环境的包可以用cdn加载,这样减少你生产环境的bundle.js的体积,开发环境那部分依赖的包就可以单独cdn引入,进而提升你项目的打包速度。


打开node_modules/ramda,我们能从这个优秀的ramda库中发现些什么, 注意scripts


scripts配置中有一个"build": "npm run build:es && npm run build:cjs && npm run build:umd && npm run build:umd:min && npm run build:mjs",ramda是用rollup打包的,这行命令可以将你的ramda打包成不同模式,不仅支持按需引入还是script标签引用的多种方式。关于rollup打包,可以参考官网学习rollup.js[2]


现在我们测试下自己配置的scripts,当前目录下新建一个文件index.js,并控制台运行npm run start

  {
  "name": "npm-know",
  "version": "1.0.0",
  "description": "My first encounter with npm",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "start": "node index.js"
  },
  ...
}

index.js写入测试代码

// 由于刚项目已经安装ramda,所以直接require该包
const R = require('ramda');
const cityMap = [
    {
        city: '北京',
    },
    {
        city: '上海'
    },
    {
        city: '深圳'
    }
];
// 找到上海
const shanghaiCity = R.find(R.propEq('city', '上海'))(cityMap)
console.log(shanghaiCity)

测试结果如下:

44466066c031ebf9d2f47f9a3ef4c4a2.jpg

在你执行npm run start时,它与npm start也是等价的,实际上当我们执行这行命令时本质上在执行node index.js,前者相当于一个命令的别名,所以你看到ramdascripts上配置了多行命令,"build": "npm run build:es && npm run build:cjs && npm run build:umd && npm run build:umd:min && npm run build:mjs",,在ramda中,这行命令执行了多行配置


npm init生成的package.json内部还有其他的字段,更多可以参考官方文档pckage.json[3],你已经了解npm最硬核的一些知识了,其它的,你就熟悉些配置时,比如支持操作系统、node 指定环境版本等等,巴拉巴拉...

5fc6a0a405d37798234eacf84f57a106.jpg


npm -h


npm -h

这是一个查看npmcmmand 有那些指令,等价于npm help,如果你记不起 npm 有哪些命令,那么你可以用这个查看她的全家桶

9256e4b7bf1aaf0501726a2b2f70fde7.jpg


npm i(npm install的简写)



npm i 
// npm i -g 全局安装
// npm i xx@latest 安装最新xx版本的包
// npm i xx@1.x.x 安装指定版本的包
// npm i xx@1.x.x -s or npm i xx@1.x.x -d 安装到开发环境,包名会在dependencies
// npm i xx@1.x.x --save-dev 安装到生产环境,包名会在devDependencies

如果你package.jsondependencies或者devDependencies有对应的包了,那么你执行该命令后,会在你当前项目中生成一个node_modules文件夹,该文件下会下载你需要的包,应有尽有。


npm cache clear


npm cache clear

清除缓存包,在你运行项目,莫名其妙的报错的时候,除了删除node_modules,有时候你执行这个命令,可能能帮助到你


npm bugs xxx


npm bugs ramda

这是一个很有用的命令,快速链接到你这个包的issue,在issue中会找到你遇到的一些问题,例如:cd node_modules/ramda,执行命令npm bugs,浏览器自动给你打开了该包issue地址。(如果只是在你自己的项目根目录里,执行这个命令,这个命令会把以当前package.json的 name,在 npm官网当成一个路由地址打开,那么就是 404 了,不信你可以试试)。

c4e1532cccfe7006159cd0c43029c4d0.jpg


npm view ramda versions


查看ramda所有版本包

npm view ramda versions
// npm view ramda version  查看当前项目ramda版本
// npm view ramda@* 查看当前包的基本信息

c9f609b6df4b0a5752bf078a07712a1a.jpg

如果你本地想安装一个vue指定的版本,那么你可以先npm view vue versions 查到所有的版本,然后命令安装npm i vue@3.2.25 -s那么就会安装该版本。


npm diff --diff=ramda@0.0.1 --diff=ramda@0.1.0


npm diff --diff=ramda@0.0.1 --diff=ramda@0.1.0

比较两个版本的不同,用到少。


npm docs ramda


npm docs ramda

这个命令打开ramda的官方文档,就是package.json里面的那个homepage地址


npm update xxx


更新xxx包

npm update ramda // 更新ramda包


npm uninstall xxx


卸载xxx包

npm uninstall ramda
// 简写,等价于下面  npm un ramda or npm rm ramda or npm r ramda


npm pkg get xx1 xx2


npm pkg get name version

读取包名、版本等信息

4c6e5d0a188a405ecc8bb3578ff86120.jpg

接下来说几个关于npm发包的几个关键命令


npm login


npm login 

491af22d51929d3a505a2f827813b18c.jpg

这中途需要npm官方会给你发邮箱验证码,收到npm注册的邮箱验证码,然后输入就OK了,这里以笔者n年前上传的一个包eazyutils包为例。


npm publish


npm publish

296f2d2d282715ae80e6b2d92ed52c6f.png

(注意修改下package.json的版本),否则提交不上


更多npm命令参考npm commands[4]了,不常用的就没写了,因为那些不常用的。关于更多npm的命令最好的学习方式就是找官方文档查询,本以为你看到这里,以为总结了所有npm命令,但是....,笔者文章已经覆盖了项目里所用到的绝大部分场景。


总结


  1. npm常用的command命令,譬如高频命令npm view xxx versions,npm update@lastestnpm un xxxnpm i xx -s,常用的增删查改基本已经涵盖了。
  2. 了解package.json关键的几个字断意思,但是bin这个你必须要知道,因为她,你可以任性创建一个自己的xx-cli
  3. npm如何发布一个全世界都能看到,全世界都能下载的npm包,以n年前的一个简单eazyutils包为例。
相关文章
|
8月前
|
JavaScript 前端开发 数据安全/隐私保护
详细介绍NPM的基本使用方法、常用命令和一些实用技巧
详细介绍NPM的基本使用方法、常用命令和一些实用技巧
253 0
|
8月前
|
Ubuntu
node、npm 命令升级
node、npm 命令升级
142 0
|
8月前
设置VSCode运行任务命令快捷键Alt+R,通常用于npm start(对频繁使用该命令可节省50%的输入命令行打字时间)
设置VSCode运行任务命令快捷键Alt+R,通常用于npm start(对频繁使用该命令可节省50%的输入命令行打字时间)
|
8月前
|
JavaScript 前端开发 Shell
NPM 自定义 package.json 中 scripts 命令(& 与 && 的区别,cross-env 的使用)
NPM 自定义 package.json 中 scripts 命令(& 与 && 的区别,cross-env 的使用)
290 0
|
7月前
|
缓存 JavaScript 前端开发
npm命令介绍
npm命令介绍
|
6月前
|
缓存 JavaScript 前端开发
npm常用命令详解与实践
npm常用命令详解与实践
|
6月前
|
JavaScript
TS,编写TS文件,编写hello.ts文件,cmd下打开终端,输入tsc hello.ts会生成一个hello.js文件,简化命令,npm i -g ts-node,ts-node hello.ts
TS,编写TS文件,编写hello.ts文件,cmd下打开终端,输入tsc hello.ts会生成一个hello.js文件,简化命令,npm i -g ts-node,ts-node hello.ts
|
8月前
|
JSON JavaScript 数据安全/隐私保护
npm命令:常用npm命令及其详解!
npm命令:常用npm命令及其详解!
|
7月前
|
JavaScript
# 解决输入任何npm命令都报Error: Cannot find module ‘are-we-there-yet‘
# 解决输入任何npm命令都报Error: Cannot find module ‘are-we-there-yet‘
|
8月前
|
JavaScript Unix Shell
#! /usr/bin/env node 命令与 npm link 建立项目间软连接(一)
#! /usr/bin/env node 命令与 npm link 建立项目间软连接(一)
231 0

热门文章

最新文章

推荐镜像

更多