npm的使用

npm介绍

  • NPM的全称是Node Package Manager,是一个NodeJS包管理和分发工具
  • NPM的作用:
    允许用户从NPM服务器下载别人编写的第三方包到本地使用。
    允许用户从NPM服务器下载并安装别人编写的命令行程序到本地使用。
    允许用户将自己编写的包或命令行程序上传到NPM服务器供别人使用。

npm的基本命令

  • npm init
    运行构建新项目的向导
  • npm install module_name
    在项目中安装一个模块
  • npm install -g module_name
    全局方式安装一个模块
  • npm install module_name –save
    在项目中安装一个模块,并把此模块添加到项目配置文件package.json中,作为项目依赖
  • npm install module_name –save-dev
    在项目中安装一个模块,并把此模块添加到项目配置文件package.json中,作为项目开发依赖(devDependency)
  • npm list
    列出项目中已安装的所有模块
  • npm list -g
    列出系统中全局安装的所有模块
  • npm remove module_name
    从项目中移除已安装的模块
  • npm remove -g module_name
    从系统的全局安装中移除已安装的模块
  • npm remove module_name –save
    从项目中移除已安装的模块,并从配置依赖中移除依赖关系
  • npm remove module_name –save-dev
    从项目中移除已安装的模块,并从配置依赖中移除开发依赖(devDependency)关系
  • npm update module_name
    更新指定的已安装模块的版本
  • npm update -g module_name
    更新指定的全局安装模块的版本
  • npm -v
    显示npm包管理器的当前版本
  • npm adduser username
    在npmjs.org创建一个账户
  • npm whoami
    显示你在npmjs.org上的账户详细信息
  • npm login
    登录账户
  • npm publish
    发布自己开发的模块到npmjs.org,要发布模块必须先有账户
  • npm set registry https://registry.npm.taobao.org
    将源地址修改为淘宝NPM镜像
  • npm config set registry https://registry.npmjs.org
    修改源地址为官方源(发布npm包时必须使用官方源)

package.json说明

当我们使用 npm init 命令来创建一个新的项目(模块)时,会生成package.json用来对该项目进行相关描述:

bin的作用:
package.json
{
  "name": "yanxintest",
  "version": "1.0.11",
  "description": "test npm",
  "main": "index.js",
  "bin": {
        "sayhello": "./bin/sayhello"
    },
  "author": "yanxin",
  "license": "ISC"
}

"sayhello": "./bin/sayhello"表明了在和package.json同级目录下,存在一个bin文件夹,其中有个sayhello文件.

01.png

02.png

该sayhello文件中包含的是可以在nodejs中运行的JavaScript语句

// sayhello文件
#!/usr/bin/env node   
console.log("hello npm!");

其中,!/usr/bin/env node表明了这是在nodejs环境中运行的.

当用户全局安装该npm工具时,会在/usr/local/bin/(视具体情况而定) 目录下创建快捷方式sayhello,该快捷方式指向了/usr/local/lib/node_modules/npm工具名称/bin目录下的sayhello文件.

当在命令行中输入sayhello命令时,nodejs会自动运行对应的sayhello文件,执行相应的操作.

scripts的作用:

npm允许在package.json文件里面,使用scripts字段定义脚本命令

//...
"scripts" : {
    "build": "node build.js"
}

上面的代码时package.json文件的一个片段,里面的scripts字段是一个对象.它的每一个属性,对应一段脚本.例如,build命令对应的脚本时node build.js.

命令行下使用 npm run 命令,就可以执行这段脚本.

$ npm run build
# 等同于执行
$ node build.js
  • 注意: 要在package.json所在路径下使用对应的npm run命令

例子说明:

{
    "name": "demo01",
    "version": "1.0.0",
    "description": "",
    "main": "index.js",
    "scripts": {
        "test": "echo \"Error: no test specified\" && exit 1",
        "webpack": "webpack app.js app.merge.js"
    },
    "author": "",
    "license": "ISC",
    "devDependencies": {
        "webpack": "^2.3.2"
    }
}

scripts中的"webpack": "webpack app.js app.merge.js",当运行npm run webpack时,会优先从 ./node_modules/.bin/目录中去找webpack文件(该文件是和./node_modules/webpack/bin/webpack.js是一致的),如果存在webpack文件,则运行该文件,如果不存在则会在全局安装npm模块的目录下去寻找相应的文件(在usr/local/bin目录下的webpack文件是个快捷方式,它指向了usr/local/lib/node_modules/webpack/bin/webpack.js)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 如何全局安装一个 node 应用? npm install -g module_name package.json...
    IT男的成长记录阅读 373评论 0 0
  • 关键词:npm 定义:npm 允许在package.json文件里面,使用scripts字段定义脚本命令。 上面代...
    ferrint阅读 13,635评论 2 6
  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 8,281评论 7 35
  • 最近在学习 Webpack,网上大多数入门教程都是基于 Webpack 1.x 版本的,我学习 Webpack 的...
    My_Oh_My阅读 8,228评论 40 247
  • 白香山去吴十年,客居洛阳,忆及苏杭旧日,填了三阙小词,最末一首是回忆姑苏:江南忆,其次忆吴宫。吴酒一杯春竹...
    十年书剑阅读 393评论 0 1