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)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 161,513评论 4 369
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,312评论 1 305
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 111,124评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,529评论 0 217
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,937评论 3 295
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,913评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,084评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,816评论 0 205
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,593评论 1 249
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,788评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,267评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,601评论 3 261
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,265评论 3 241
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,158评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,953评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,066评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,852评论 2 277

推荐阅读更多精彩内容

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