1、什么是包

Node.js中的第三方模块又叫包

2、包的来源

由第三方个人或团队开发出来的,免费供所有人使用

3、为什么需要包

由于Node.js的内置模块仅提供了一些底层的API,导致在基于内置模块进行项目开发时,效率很低。
包是基于内置模块封装出来的,提供了更高级、更方便的API,极大的提高了开发效率。

4、从哪里下载包

搜索包:https://www.npmjs.com
下载包:https://registry.npmjs.org 服务器

5、安装包

npm install 包的完整名称

初次装包完成后,在项目文件夹下多了叫做 node_modules的文件夹和 package-lock.json的配置文件

node_modules:用来存放所有安装到项目中的包。require()导入第三方包时,就是从这个目录中查找并加载包。
package-lock.json:用来记录 node_modules目录下每个包的下载信息,例如包的名字、版本号、下载地址等。

默认情况下使用npm install命令安装包的时候会自动安装最新版本的包,如果需要安装指定版本的,可以在包名后面用@符号指定具体的版本

6、包的语义化版本规范

包的版本号是以“点分十进制”形式进行定义的,总共有三位数字,例如:2.22.0

第1位:大版本(发生了底层重构)
第2位:功能版本(新增了功能)
第3位:Bug修复版本(对bug进行了修复)

版本号提升的规则:只要前面的版本号增长了,则后面的版本号归零

7、包管理配置文件

在项目根目录中,创建一个叫package.json的配置文件,即用来记录项目中安装了哪些包。从而方便剔除node_modules目录之后,在团队成员之间共享项目的源代码。

注意:在项目开发中,要把node_modules文件夹添加到.gitignore忽略文件中

1、快速创建 package.json
npm init -y

注意:上述命名只能在英文的目录下成功运行,所以项目文件夹的名称要使用英文,不要使用中文,不能出现空格

运行 npm install 命令安装包的时候,npm 包管理工具会自动把包的名称和版本号记录到package.json中。

2、dependencies节点

用来记录使用 npm install 命令安装了哪些包

3、一次性安装所有的包
npm install(或 npm i)

执行 npm install 命令时,npm 包管理工具会先读取 package.json 中的 dependencies 节点,读取到记录的所有依赖包名称和版本号之后,npm 包管理工具会把这些包一次性下载到项目中。

4、卸载包
npm uninstall 包名

npm uninstall 命令执行成功后,会把卸载的包自动从 package.jsondependencies 中移除掉。

5、devDependencies节点

如果某些包只在项目开发阶段会用到,在项目上线之后不会用到,则建议把这些包记录到devDependencies节点中。如果某些包在开发项目上线后都需要用到,则建议把这些包记录到dependencies中。

npm install 包名 --save-dev

简写:

npm i 包名 -D
6、解决包下载速度慢的问题

1、原因:在使用 npm 下包的时候,默认从国外的服务器上进行下载,此时网络数据的传输需要经过漫长的海底光缆,因此下载包速度会很慢。

2、淘宝NPM镜像服务器:淘宝在国内搭建了一个服务器,专门把从国外官方服务器上的包同步到国内的服务器,然后在国内提供下包的服务,从而极大的提高了下包的速度。
3、切换npm的下包镜像源:

# 查看当前的下包镜像源
npm config get registry
# 将下包的镜像源切换成淘宝镜像源
npm config set registry=https://registry.npm.taobao.org/
# 检查镜像源是否下载成功
npm config get registry

4、nrm

为了更方便的切换下包的镜像源,可以安装 nrm小工具,利用 nrm 提供的终端命令,可以快速查看和切换下包的镜像源

# 安装
npm i nrm -g
# 查看所有可用的镜像源
nrm ls
# 将下包的镜像源切为taobao镜像
nrm use taobao

8、包的分类

1、项目包

被安装到项目的 node_modules 目录中的包都是项目包

① 开发依赖包(被记录到 devDependencies节点中的包,只会在开发期间用到)

② 核心依赖包(被记录到 dependencies节点中的包,在开发期间和项目上线后都会用到)

# 开发依赖包
npm i 包名 -D
# 核心依赖包
npm i 包名
2、全局包

在执行 npm install 命令时,如果提供了 -g 参数,则会把包安装为全局包,全局包会被安装到 C:\Users\用户目录\AppData\Roaming\npm\node_modules目录下

# 全局安装指定的包
npm i 包名 -g
# 卸载全局安装的包
npm uninstall 包名 -g

注意:
① 只有工具性质的包,才有全局安装的必要性。因为它们提供了好用的终端命令。
②判断某个包是否需要全局安装后才能使用,可以参考官方提供的使用说明即可。

9、规范的包结构

一个规范的包,它的组成结构必须符合以下3点要求

①包必须以单独的目录而存在
②包的顶级目录下必须包含package.json这个包管理配置文件
③package.json中必须包含nameversionmain这三个属性,分别代表包名版本号入口

10、开发属于自己的包

1、需要实现的功能

① 格式化日期
② 转义 HTML 中的特殊字符
③ 还原 HTML 中的特殊字符

2、初始化包的基本结构

① 新建 ithanxu-tools 文件夹,作为包的根目录
②在ithanxu-tools文件夹中新建三个文件:package.json(包管理配置文件)、index.js(包的入口文件)、README.md(说明文档)

3、初始化 package.json
{"name": "ithanxu-tools","version": "1.0.0","main": "index.js","description": "提供了格式化时间、HTMLEscape相关的功能","keywords": ["ithanxu","dateFormat","escape"],"license": "ISC"
}
4、在dateFormat.js中定义格式化时间的方法
// 定义格式化时间的函数
function dateFormat(dataStr) {const dt = new Date(dataStr)const y = dt.getFullYear()const m = padZero(dt.getMonth() + 1)const d = padZero(dt.getDate())const hh = padZero(dt.getHours())const mm = padZero(dt.getMinutes())const ss = padZero(dt.getSeconds())return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
}// 定义补零函数
function padZero(n) {return n > 9 ? n : '0' + n
}// 向外暴露需要的成员
module.exports = {dateFormat
}
5、在htmlEscape.js中定义转义HTML和还原HTML的方法
// 定义转义HTML字符的函数
function htmlEscape(htmlStr) {return htmlStr.replace(/<|>|"|&/g,(match) => {switch (match) {case '<':return '&lt;'case '>':return '&gt;'case '"':return '&quot;'case '&':return '&amp;'}})
}// 定义还原HTML字符的函数
function htmlUnEscape(str) {return str.replace(/&lt;|&gt;|&quot;|&amp;/g,(match) => {switch(match) {case '&lt;':return '<'case '&gt;':return '>'case '&quot;':return '"'case '&amp;':return '&'}})
}// 向外暴露需要的成员
module.exports = {htmlEscape,htmlUnEscape
}
6、在index.js中导入两个模块,得到需要向外共享的方法,再把对应的方法共享出去
const date = require('./dateFormat')
const escape = require('./htmlEscape')
// 向外暴露需要的成员
module.exports = {...date,...escape
}
7、编写包的使用说明文档

包含:安装方式、导入方式、格式化时间、转义HTML中的特殊字符、还原HTML中的特殊字符、开源协议

(1)安装

npm install ithanxu-tools

(2)导入

const ithanxu = require('ithanxu-tools')

(3)格式化时间

const dtStr = ithanxu.dateFormat(new Date())

(4)转义HTML中的特殊字符

// 定义要转化的HTML字符串
const htmlStr = '<h1 title="abc">这是h1标签<span>123&nbsp;</span></h1>'
// 调用htmlEscape方法进行转化
const str = ithanxu.htmlEscape(htmlStr)
// 转化的结果:&lt;h1 title=&quot;abc&quot;&gt;这是h1标签&lt;span&gt;123&amp;nbsp;&lt;/span&gt;&lt;/h1&gt;
console.log(str)

(5)还原HTML中的特殊字符

// 调用htmlUnEscape方法进行还原
const str2 = ithanxu.htmlEscape(str)
// 转化的结果:<h1 title="abc">这是h1标签<span>123&nbsp;</span></h1>
console.log(str2)

(6)开源协议

ISC
8、发布包
1、注册npm账号

① 访问 https://www.npmjs.com/网站,点击sign up按钮进入注册页面


② 填写账号相关信息


③ 点击 Create an Account 按钮,注册账号
④登录邮箱,点击验证链接,进行账号的验证

2、登录npm账号

在终端执行 npm login 命令,依次输入用户名、密码、邮箱后即可登录成功

注意:在运行 npm login 命令之前,必须先把下包的服务器地址切换为 npm 的官方服务器,否则会导致发布包失败

3、把包发布到npm上

将终端切换到包的根目录后,运行 npm publish 命令,即可将包发布到npm上(注意:包名不能雷同

此时在npm上就上传了包:

4、删除已发布的包

运行 npm unpublish 包名 --force 命令,即可从 npm 删除已发布的包

注意:

① npm unpublish 命令只能删除 72小时以内发布的包
② npm unpublish 删除的包,在24小时内不允许重复发布
③ 发布包的时候要慎重,尽量不要往 npm 上发布没有意义的包


此时 npm 上包被删除

【nodejs】npm与包相关推荐

  1. Nodejs入门 (四) 包管理工具(npm、cnpm、yarn、nvm)

    目录 一.什么是包管理工具? 二.npm的使用 1.初始化 2.搜索包 3.下载安装包 4.安装包的使用 5.全局安装 6.安装包依赖 7.安装指定版本的包 8.删除依赖 9.配置命令别名 10.np ...

  2. 【NodeJs篇】npm和包

    1.什么是包 Node.js 中的第三方模块又叫做包. 就像电脑和计算机指的是相同的东西,第三方模块和包指的是同一个概念,只不过叫法不同 2.包的来源 不同于 Node.js 中的内置模块与自定义模块 ...

  3. nodejs npm下载使用包

    分成三步 初始化项目.npm init 如果之前已经初始化,则可以省略. 安装包. npm install 包名. 引入模块,使用. 第一步:初始化项目 这里提到的项目并不是某个具体的功能,只是要创建 ...

  4. Node.js基础知识、fs、path、http三大模块、nodejs的模块化、npm与包管理

    文章目录 一.Node.js 简介 二.fs 文件系统模块 读取指定文件中的内容 向指定的文件中写入内容 案例-考试成绩整理 fs 模块 - 路径动态拼接的问题 三.path 路径模块 路径拼接 pa ...

  5. MacOS安装react。问题 -- npm全局包的权限问题

    网上的教程有好多,在这里不一一列举,我只介绍我今天安装成功的步骤 首先,在安装react之前要先配置好node 1.安装node 在这里下载node的安装包https://nodejs.org/en/ ...

  6. 开发发布npm module包

    开发发布npm module包 问题 在项目开发过程中,每当进入一个新的业务项目,从零开始搭建一套前端项目结构是一件让人头疼的事情,就要重新复制一个上一个项目的前端框架和组件代码库.其中很多功能的模块 ...

  7. js读取外部json指定字段值完整代码_前端工程化 剖析npm的包管理机制(完整版)...

    导读 现如今,前端开发的同学已经离不开 npm 这个包管理工具,其优秀的包版本管理机制承载了整个繁荣发展的NodeJS社区,理解其内部机制非常有利于加深我们对模块开发的理解.各项前端工程化的配置以加快 ...

  8. nodejs npm报错 重装 解决方法

    #npm -v 报错 无反应 #重装node.js npm -v 还是报错   然而有一天用自己的笔记本时,用npm下载包报错了,好长时间没有修好,不能惯着破软件丑毛病卸了它(nodejs v10), ...

  9. node.js学习总结:node.js的内置模块,模块化,npm与包 express,前后端身份认证 JWT认证机制

    node.js学习总结 什么是node.js node.js的内置模块 fs系统模块 path路径模块 http模块 模块化 npm与包 express express路由 express+mysql ...

最新文章

  1. 2022-2028年中国数码相机行业投资分析及前景预测报告
  2. SAP HUM已知一个内部HU号码,如何得到HU号码?
  3. tomcat启动项目内存溢出问题
  4. Linux环境安装Mysql
  5. python处理csv文件 sql_如何用python将csv文件写入sql数据库
  6. STL 之随机访问迭代器
  7. 西门子s7-200解密软件下载_西门子S7200仿真软件如何使用?
  8. 让Eclipse变得快点,取消validation
  9. 系统无法在消息文件中为application_iOS 14 Filza 文件消息,M1 能用 win 系统
  10. java当前时间推前三个月_获取当前时间的前三个月 java
  11. mongodb 3.0版本安装
  12. 推荐Python十大经典练手项目,让你的Python技能点全亮!
  13. ToolsOh第4批收录
  14. 小米平板完整bios_小米平板bios设置u盘启动操作步骤
  15. JavaWeb宿舍管理系统环境搭建运行教程
  16. 程派高式八卦掌传人——刘树行
  17. 搜狗大数据总监、Polarr 联合创始人关于深度学习的分享交流 | 架构师小组交流会...
  18. 计算机网络——各层次网络互联设备
  19. 【人工智能】从数据预处理到排序算法,全方位解读 Uber 人工智能客服 COTA
  20. 基于SVM的数据分类预测——意大利葡萄酒种类识别

热门文章

  1. 亲测好用!四款ps小白也能用的宣传印刷物料!
  2. GD32F4xx CAN 过滤器设置
  3. Echarts 南海诸岛简图显示位置调整
  4. 2022-2028年全球与中国奶酪格栅机行业市场需求预测分析
  5. linux杀毒软件clamav,linux杀毒软件-clamav
  6. 本博开始交换链接,衷心希望各位博友赏脸
  7. 利用sqlmap进行文件读写
  8. 指标实现层级_有了指标怎么用层次分析法建立模型?
  9. Linux的任督二脉:进程调度和内存管理
  10. 企业级开发:Gitflow Workflow工作流