记一次发布/更新npm包的过程及包版本管理
您可以发布包含package.json
文件的任何目录。这里如何首次发布程序包以及如何在以后更新程序包。
如何发布包
制备
了解npm政策
在开始之前,如果您对网站礼仪,命名,许可或其他指南有疑问,最好查看npm的政策。
创建用户帐户
要发布,您必须是npm注册表中的用户。如果您不是用户,请使用 npm adduser
创建帐户。如果您在网站(https://www.npmjs.com/)上创建了用户帐户,请使用npm login
从终端访问您的帐户。
**下图显示已登录成功到npm**
测试:
- 键入
npm whoami
从终端看,如果你已经登录(从技术上讲,这也意味着你的证书已经存储在本地)。 - 检查您的用户名是否已添加到注册表https://npmjs.com/~username。(username为账户名),例如:
新建项目文件夹并在当前文件夹打开cmd命令,接着输入npm init创建package.json
查看包目录
此时文件夹中会生成一个package.json文件
查看内容
请注意,除非本地.gitignore
或.npmignore
文件忽略该目录,否则将包含目录中的所有内容。要了解如何使用这些命令,请参阅npm-developers
。
查看package.json文件
阅读使用package.json
以确保所需的详细信息反映在您的包中。
选择一个名字
为您的包选择一个唯一的名称。尝试选择一个描述性名称:
- 还没有其他人拥有
- 除了拼写错误之外,拼写不会像其他名字一样拼写
- 不会混淆他人的作者身份
- 符合npm政策指南。例如,不要将您的包命名为冒犯性的,也不要使用其他人的商标名称。
- 在package.json文件的相应行中指定名称。
注意:如果您使用范围,则前3个警告不适用。
包含文档(readme.md)
npm建议您包含一个自述文件来记录您的包。自述文件必须具有文件名readme.md
。文件扩展名.md
表示该文件是markdown文件。当有人找到您的包裹时,此文件将显示在npm网站上。
在开始之前,请查看一些软件包页面,以获取可以添加到自述文件中的信息的想法,并了解为什么这么重要。
- 使用任何文本编辑器创建文件。
- 将其保存在项目目录中,名称为readme.md
- 发布时,此文档将显示在人们下载程序包的网页上。
可以先在有道云笔记上新建一个Markdown文件,编辑完成后再复制到包中替换Readme.md文件
在npm官网上显示readme.md文件如下:
登录npm账号并使用npm publish
发布包。
输入npm login;登陆自己的账号,密码,邮箱
测试
去https://npmjs.com/package/<package>
。你应该看到一个关于你的新包的页面。它可能看起来像这样:
恭喜!
如何更新包
如何更新版本号
进行更改时,可以使用更新包
npm version <update_type>
其中<update_type>是语义版本控制版本之一,补丁,次要或主要版本。
此命令将自动更改版本号package.json中的
version字段值。
此处延伸一下版本号管理的内容:
版本号
语义化版本:https://semver.org/lang/zh-CN/
版本号格式:主版本号.次版本号.修订号
版本号递增规则:
- 主版本号:做了不兼容修改或颠覆式的重写
- 次版本号:向下兼容的功能性新增
- 修订号:向下兼容的问题修正
先行版本号及版本编译信息可以加到“主版本号.次版本号.修订号”的后面,作为延伸。
版本号只能增加,禁止下降,代码的修改必须以新版本形式更新;最初版本建议是从v0.1.0开始,0.x.y阶段是基础功能、公众API开发阶段。
1.0.0版本发布时机:
- 被用于正式环境
- 稳定的API被使用者依赖
- 很担心向下兼容的问题
万一不小心把一个不兼容的改版当成了次版本号发行了该怎么办?一旦发现自己破坏了语义化版本控制的规范,就要修正这个问题,并发行一个新的次版本号来更正这个问题并且恢复向下兼容。即使是这种情况,也不能去修改已发行的版本。
npm管理项目版本号
在命令行窗口输入npm version ?可以查看可以使用的命令:
执行命令及版本提升示例:
假设初始版本为0.1.0
➜ xxx git:(master) npm version preminor
v0.1.0-0
➜ xxx git:(master) npm version minor
v0.1.0
➜ xxx git:(master) npm version prepatch
v0.1.1-0
➜ xxx git:(master) npm version patch
v0.1.1
➜ xxx git:(master) npm version prerelease
v0.1.2-0
➜ xxx git:(master) npm version premajor
v1.0.0-0
➜ xxx git:(master) npm version major
v1.0.0
如果使用git进行项目管理,在进行版本提升前,需要将修改内容提交,即commit,然后再执行npm version xxx
进行版本提升,版本提升会自动被提交到当前分支中,可以通过git log
进行查看。
注意:如果您已将一个标签与您的npm帐户相关联,那么这也会将更新后的版本号添加到您的git存储库中。
更新版本号后,npm publish
再次运行。
测试:转到https://npmjs.com/package/<package>
。包裹号码应该更新。
如何更新自述文件
除非发布新版本的软件包,否则不会更新网站上显示的自述文件,因此您需要运行npm version patch
并npm publish
更新网站上显示的文档。
记一次发布/更新npm包的过程及包版本管理的更多相关文章
- 如何发布一个包到npm && 如何使用自己发布的npm包 && 如何更新发布到npm的package && 如何更新当前项目的包?
如何发布一个包到npm First 在https://www.npmjs.com注册一个账号. Second 编辑好项目,文件大致如下: 其中,gitignore可以如下: .DS_Store nod ...
- 利用npm安装/删除/发布/更新/撤销发布包 --社会我npm哥,好用话不多
一.什么是npm? npm是javascript的包管理工具,是前端模块化下的一个标志性产物 简单地地说,就是通过npm下载模块,复用已有的代码,提高工作效率 1.从社区的角度:把针对某一特定 ...
- (转)前端开发-发布一个NPM包之最简单易懂流程
原文地址:https://www.cnblogs.com/sghy/p/6829747.html 1.npm官网创建npm账户 npm网站地址:https://www.npmjs.com/ npm网站 ...
- 创建自己的library类库包并使用webpack4.x打包发布到npm
创建自己的library类库包并使用webpack4.x打包发布到npm 我们在开发过程中,可能经常要使用第三方类库,比如jquery.lodash等.我们通过npm,下载安装完之后,就可以使用了,简 ...
- 如何发布一个npm包(基于vue)
前言:工作的时候总是使用别人的npm包,然而我有时心底会好奇自己如何发布一个npm包呢,什么时候自己的包能够被很多人喜欢并使用呢...今天我终于迈出了第一步. 前提:会使用 npm,有 vue 基础, ...
- 【npm】利用npm安装/删除/发布/更新/撤销发布包
什么是npm? npm是javascript的包管理工具,是前端模块化下的一个标志性产物 简单地地说,就是通过npm下载模块,复用已有的代码,提高工作效率 1.从社区的角度:把针对某一特定问题 ...
- webpack创建library及从零开始发布一个npm包
最近公司有个需求,我们部门开发一个平台项目之后,其他兄弟部门开发出的插件我们可以拿来直接用,并且不需要我们再进行打包,只是做静态的文件引入,研究一波后发现,webpack创建library可以实现. ...
- 通过NPM快速发布你的NodeJS模块(组件包)
1.更新 NPM - [ npm install -g npm | 该步骤可选:最好使用新版本] 楼主当前版本号 2.6.1 ,如果更新报错,可以尝试 国内淘宝镜像 $ npm -v 2.6.1 // ...
- 利用npm安装/删除/发布/更新/撤销发布包
利用npm安装/删除/发布/更新/撤销发布包 什么是npm? npm是javascript的包管理工具,是前端模块化下的一个标志性产物 简单地地说,就是通过npm下载模块,复用已有的代码,提高工作效率 ...
随机推荐
- CSS3新增伪类有那些?
p:first-of-type 选择属于其父元素的首个元素 p:last-of-type 选择属于其父元素的最后元素 p:only-of-type 选择属于其父元素唯一的元素 p:only-child ...
- JavaWeb项目:旅游网站【涉及各种知识】
JQuery异步请求(ajax) $.ajax({ // 请求方式为get或者post等 type: "GET", // 服务器响应的数据类型 dataType: "js ...
- Java实现 蓝桥杯VIP 算法提高 排队打水问题
算法提高 排队打水问题 时间限制:1.0s 内存限制:256.0MB 问题描述 有n个人排队到r个水龙头去打水,他们装满水桶的时间t1.t2----tn为整数且各不相等,应如何安排他们的打水顺序才能使 ...
- Java实现 LeetCode 136 只出现一次的数字
136. 只出现一次的数字 给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 说明: 你的算法应该具有线性时间复杂度. 你可以不使用额外空间来实现 ...
- 第四届蓝桥杯JavaB组省赛真题
解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.世纪末星期 题目描述 曾有邪教称1999年12月31日是世界末日.当然该谣言已经不攻自破. 还有人称今后的某个世纪末的12月31日,如 ...
- Java实现 LeetCode 137 只出现一次的数字
public static int singleNumber(int[] nums) { int res = 0; for(int i=0;i<nums.length;i++) res ^= n ...
- java实现最大五个数
** 最大5个数** [12,127,85,66,27,34,15,344,156,344,29,47,....] 这是某设备测量到的工程数据. 因工程要求,需要找出最大的5个值. 一般的想法是对它排 ...
- C# 反射详解一
首先反射是基于System.Reflection命名空间下,.Net框架提供的帮助类库,可以读取并使用metadata(元数据:描述对象信息的数据). 我们再来看下代码生成编译的总过程. 编译器编译( ...
- gitee+picgo搭建个人博客图床
gitee+picgo搭建个人博客图床 准备 首先需要去码云注册一个账号,并新建一个仓库.接着下载PicGO并安装好. 过程 点击左下方的插件设置. image 在搜索框中输入gitee搜索插件,安装 ...
- Cypress系列(0)- 如何学习 Cypress
如果想从头学起Cypress,可以看下面的系列文章哦 https://www.cnblogs.com/poloyy/category/1768839.html 前言 Cypress 未来很有可能会火的 ...