前言
随着前端工程的发展,npm
已然成为每个前端开发者的必备技能,然而大多数人对它的使用也只是停留在使用npm
安装一些依赖包而已。作为全世界最大规模的包管理器,每周大约有30亿次的下载量,npm
的功能远不止安装依赖这么简单,本文的目的就是介绍npm
更多的功能。
安装
通过安装NodeJS,就会连带安装。
使用
- 查看npm版本
$ npm -v
- 更新npm版本
$ npm install npm@latest -g
- 初始化与安装依赖包
npm init (-y)
此指令用来安装初始化一个package.json
文件,-y表示生成一个默认的文件,不需要一步一步的来。
{
"name": "vue-music",
"version": "1.0.0",
"description": "vue组件化开发音乐播放器",
"author": "author",
"private": true,
"scripts": {
"dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
"start": "npm run dev",
"lint": "eslint --ext .js,.vue src",
"build": "node build/build.js"
},
"dependencies": {
"babel-runtime": "^6.26.0",
"fastclick": "^1.0.6",
"vue": "^2.5.2",
"vue-router": "^3.0.1"
},
"devDependencies": {
"autoprefixer": "^7.1.2",
"babel-core": "^6.22.1",
"babel-eslint": "^8.2.1",
"babel-helper-vue-jsx-merge-props": "^2.0.3",
"babel-loader": "^7.1.1",
"babel-plugin-syntax-jsx": "^6.18.0",
"babel-plugin-transform-runtime": "^6.22.0",
"babel-plugin-transform-vue-jsx": "^3.5.0",
"babel-polyfill": "^6.26.0",
"babel-preset-env": "^1.3.2",
"babel-preset-stage-2": "^6.22.0",
"chalk": "^2.0.1",
"copy-webpack-plugin": "^4.0.1",
"css-loader": "^0.28.0",
"eslint": "^4.15.0",
"eslint-config-standard": "^10.2.1",
"eslint-friendly-formatter": "^3.0.0",
"eslint-loader": "^1.7.1",
"eslint-plugin-import": "^2.7.0",
"eslint-plugin-node": "^5.2.0",
"eslint-plugin-promise": "^3.4.0",
"eslint-plugin-standard": "^3.0.1",
"eslint-plugin-vue": "^4.0.0",
"extract-text-webpack-plugin": "^3.0.0",
"file-loader": "^1.1.4",
"friendly-errors-webpack-plugin": "^1.6.1",
"html-webpack-plugin": "^2.30.1",
"node-notifier": "^5.1.2",
"optimize-css-assets-webpack-plugin": "^3.2.0",
"ora": "^1.2.0",
"portfinder": "^1.0.13",
"postcss-import": "^11.0.0",
"postcss-loader": "^2.0.8",
"postcss-url": "^7.2.1",
"rimraf": "^2.6.0",
"semver": "^5.3.0",
"shelljs": "^0.7.6",
"stylus": "^0.54.7",
"stylus-loader": "^3.0.2",
"uglifyjs-webpack-plugin": "^1.1.1",
"url-loader": "^0.5.8",
"vue-loader": "^13.3.0",
"vue-style-loader": "^3.0.1",
"vue-template-compiler": "^2.5.2",
"webpack": "^3.6.0",
"webpack-bundle-analyzer": "^2.9.0",
"webpack-dev-server": "^2.9.1",
"webpack-merge": "^4.1.0"
},
"engines": {
"node": ">= 6.0.0",
"npm": ">= 3.0.0"
},
"browserslist": [
"> 1%",
"last 2 versions",
"not ie <= 8"
]
}
上面的代码是一个vue-cli2.0生成的项目里的package.json
文件,此文件用来记录项目的一些初始化信息和依赖包的信息。
通过npm install <package-name>
或者缩写为npm -i <package-name>
来安装依赖到package.json同级目录node-modules
文件夹下。
一般我们项目中会有两个依赖环境:
- 生产环境 devDependencies
- 开发环境 dependencies
使用npm install <package-name> --save
来安装依赖包到开发环境 (dependencies)
使用npm install <package-name> --save-dev
来安装依赖包到生产环境 (devDependencies) - 全局安装
使用npm install <package-name> -g
将依赖安到全局使用,比如vue-cli。
- npm查询依赖包
npm list // 查看当前目录下已安装的node包
npm search <package-name>// 检验某个包名是否已存在
npm view <package-name> versions// 检验某个包名全部版本信息
npm view <package-name> version// 检验某个包名最新版本信息