什么是npm,怎么发包到npm

1.什么是npm

在node.js中有许多的第三方模块(简称包,我们常说的插件/工具),npm.Inc公司提供了一个专门查询这些第三方包的网址https://www.npmjs.com/;

查询到了想要的包后就需要下载,那么npm.Inc公司提供了一个下载这些第三方包的服务器地址https://registry.npmjs.org/;

npm的全称是Node Package Manageer(Node包管理工具),使用这个工具就可以下载我们常说的插件(工具),其实就是第三方包;

这个包管理工具随着Node.js的安装就会一起安装好,所以前端开发需要的环境node.js是必不可少的

2.使用npm工具安装第三方包

在项目根目录下启动终端输入npm install 包名称;可以简写成npm i 包名称,默认安装最新版本

安装指定的版本使用@+版本号,例如npm i moment@2.30.1

想替换某个版本直接输入安装命令就会替换无需卸载,例如2.30.1替换成2.0.1,例如npm i moment@2.0.1

版本号的含义说明,例如2.30.1

第一位数:大版本,该包从底层逻辑有重大重构时第一位数会发生变化

第二位数:功能版本,该包有功能性更新时第二位数会发生变化

第三位数:Bug修复版本,该包修复了Bug时所更新的版本

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

3.npm安装第三方包的方式的理解

http://t.csdnimg.cn/IBAk3

4.将自己的包发布到npm

4.1 注册npm账号

4.1.1 访问 https://www.npmjs.com 点击sign up按钮,进入注册用户界面

4.1.2 填写账号相关的信息

4.1.3 点击Create an Account按钮,提交注册

4.2.在终端登录npm账号

4.2.1 需要先切换npm的服务器为官方服务器而非淘宝镜像服务器

npm官方服务器:npm config set registry https://registry.npmjs.org/

淘宝镜像服务器:npm config set registry=https://regidtry.npm.taobao.org/

说明:所有包都是在npm官方服务器,因为这是海外服务器,因此我们国内要下载这些包就比较慢;因此,国内就自己搞了一个服务器(淘宝镜像服务器),这个服务器和npm官方服务器一模一样,也可以下载所有第三方包。这个服务器是将npm官方服务器中的包缓存在这个服务器中,会不断地更新,因此,我们下载这些包就可以更快

4.2.2 在终端输入npm login命令,以此输入用户名 密码 邮箱后,即可登录成功

说明:可能会遇到问题,解决方法看npm login问题汇总-CSDN博客

4.3.把包发布到npm上

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

4.4.删除已发布的包

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

4.4.2 npm unpublish 删除包只能删除72小时以内发布的包,删除之后24小时以内不许重复发布

相关推荐
用户904438163246027 分钟前
大三面字节被问懵?手撕 WebSocket 与 SSE 底层原理,大厂通关指南
前端·面试
蓝黑202030 分钟前
Vue SFC Playground
前端·javascript·vue.js
qq_4061761431 分钟前
React与Vue异同点及优缺点深度解析
前端·vue.js·react.js
广州华水科技32 分钟前
GNSS位移监测技术在基础设施安全中的应用与单北斗变形监测系统的优势解析
前端
Moment35 分钟前
不懂模块化就别谈前端工程化
前端·javascript·面试
majingming1238 小时前
FUNCTION
java·前端·javascript
A_nanda9 小时前
Vue项目升级
前端·vue3·vue2
SuperEugene9 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
abigale0310 小时前
【浏览器 API / 网络请求 / 文件处理】前端文件上传全流程:从基础上传到断点续传
前端·typescript·文件上传·vue cli
子兮曰10 小时前
Bun v1.3.11 官方更新全整理:新增功能、关键修复与升级验证
javascript·node.js·bun