npm 发包
前几天封装了公用的locaStorage组件,当然封装后需要发布npm官网,于是摸索了一番终于搞定了,总结下来希望对大家有所帮助
npm安装的package一般支持下面几大类:
本地包
url远程包
仓库中的包
之前有写过如何链接本地和仓库中的包,想了解的可以点这里,下面进入正题介绍npm发布包包到公共的平台上
一 npm包发布
1.注册包仓库账号
为了维护包,NPM必须要使用仓库账号才允许将包发布到仓库中。注册账号的命令是npm adduser。
$ npm adduser
Username:
Password:
Email:
当然注册也可以直接到官网注册结果是一样的
登陆 https://www.npmjs.com 用邮箱注册接收验证邮件验证就完事了
(此处有两封邮件:Welcome to npm和Verify your npm email address )
如果已经注册账号:
则我们用npm login 登录即可
证明是否登录成功:
npm who am i
2.发布
$ npm init //生成package.json,如果有就不用了
$ npm publish [floder] //不带参数默认是当前目录
如果你以后修改了代码,然后想要同步到 npm 上的话请修改 package.json 中的 version 然后再次 publish,更新的版本上传的版本要大于上次
3.权限
管理包权限:
通常,一个包只有一个拥有权限进行发布。如果需要多人进行发布,可以使用npm owner 命令帮助你管理包的所有者:
使用这个命令,也可以添加包的拥有者,删除一个包的拥有者:
$ npm owner ls <package name>
$ npm owner add <user> <package name>
$ npm owner rm <user> <package name>
注:完全符合CommonJS规范的包目录应该包含如下这些文件。
npm包实际是一个存档文件,即一个目录直接打包为.zip或tar.gz格式的文件,安装后解压还原为目录。我们开发npm包模块的时候,就可以按照以下目录结构,进行开发:
package.json : 包描述文件。
bin: 用于存放可执行二进制文件的目录。
lib:用于存放javascript代码的目录。
doc:用于存放文档的目录。
test: 用于存放单元测试用例的代码。
4.删除发过的npm包
$ npm --force unpublish testxxxxx
注:删除要用force强制删除。超过24小时就不能删除了。自己把握好时间。(删除npm包 ,很难删除,因为怕线上有人在用)
二 npm包发布问题及解决
1.使用 cnpm 的注意报错:
no_perms Private mode enable, only admin can publish this module
设置回原本的就可以了:
npm config set registry http://registry.npmjs.org
建议国内采用淘宝的cnpm,发包的时候使用npm 传送门
2.
You cannot publish over the previously published version
npm包package.json中registory属性一定要填写,每次publish npm时package.json中version版本一定要大于上一次。
3.这样的报错信息,往往是没有登录成功
npm publish failed put unexpected status code
操作npm login
4.
you do not have permission to publish "your module name". Are you logged in as the correct user?
如果你确定你的包名没有被占用,还有一种可能是本地测试的时候link过或安装过,缓存中已经存在该包,但是测试的时候信息不一致造成的,删除用户npm目录下的自己的包,尝试重新publish。
Request Entity Too Large
这种一般是因为包目录下包含了多余的或者不需要上传到npmjs的文件,在包目录下新建一个.npmignore忽略了就行,规则类似.gitignore
6.
you must verify your email before publishing a new package
这种需要你先验证你的邮箱,可能网速会很慢只要你填写了一个邮件地址,npm就会发一封邮件到你的邮件地址上,打开填写的邮件地址验证即可
三 github项目徽章的添加和设置
如果想让自己的npm包看上去更高大尚一些,可以添加一些徽章,添加徽章很简单可以点击这里去添加想要的徽章
没有伞的孩纸只能拼命奔跑
npm 发包的更多相关文章
- npm发包注意
ES6语法的包需要转换为ES5语法 安装bebel npm install --save-dev babel-cli babel-preset-es2015 babel-preset-es2017 b ...
- npm 发包的简易流程
发包的简易流程: https://www.jianshu.com/p/ea64fd01679c 错误集锦: npm publish error: 403. You do not have permi ...
- npm发包流程
1.注册npm 账号 https://www.npmjs.com/signup 2.初始化npm项目 npm init 根据发的包进行填写: { "name": "wen ...
- 基于travis和git tag 实现npm自动化发版
最近又把烂尾的开源项目alfred-femine拾起来了,这个项目旨在开发一系列前端常用的alfred workflow,提供前端开发的查询效率.时隔这么久,再次搞起,希望自己能够一直维护下去,也欢迎 ...
- npm发布包的那些事
npm发包的那些事 最近一直在研习关于node的知识,发布包虽然是最基础的一点,但由于一些地方的不注意很容易发生错误,我整理了我可能出现过的一些发布包的过程中的一些error,现在分享给大家: 正确的 ...
- 魔改了一下bootstrap-treeview组件,发布个NPM包体验一下
前言 之前在这篇文章 基于.NetCore开发博客项目 StarBlog - (8) 分类层级结构展示 中说到,我为了让文章分类列表支持层级结构,用了一个树形组件,不过这个组件太老了,使用的Boots ...
- 发布自己的npm组件库
发布自己的npm组件库 前期准备 **git上建立自己的仓库,这样子是为了在本地初始化时,可以直接生成对应的 package.json ** 克隆仓库 创建仓库成功后,gitbush本地,执行 git ...
- 打造自己的 JavaScript 武器库(转自SegmentFault公众号)
2017-11-14 SlaneYang SegmentFault 自己打造一把趁手的武器,高效率完成前端业务代码. 前言 作为战斗在业务一线的前端,要想少加班,就要想办法提高工作效率.这里提一个小点 ...
- 打造自己的 JavaScript 武器库
原文 https://segmentfault.com/a/1190000011966867 github:https://github.com/proYang/outils 前言 作为战斗在业务一线 ...
随机推荐
- WIN32 API ------ 最简单的Windows窗口封装类
1 开发语言抉择 1.1 关于开发Win32 程序的语言选择 C还是C++ 在决定抛弃MFC,而使用纯Win32 API 开发Window桌面程序之后,还存在一个语言的选择,这就是是否使用C++.C+ ...
- [Usaco2011 Feb]Generic Cow Protests
Description Farmer John's N (1 <= N <= 100,000) cows are lined up in a row and numbered 1..N. ...
- _bzoj2002 [Hnoi2010]Bounce 弹飞绵羊【分块】
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2002 见一周目记录:http://www.cnblogs.com/ciao-sora/p/6 ...
- solr 管理页面详解
solr 服务器管理界面可以查看系统状态.solr设置.分词检测.查询索引.增减core.查看日志等 1.Dashboard(仪表盘) 访问http://localhost:8080/solr时,出现 ...
- .NET框架概述
.NET战略目标: 任何时候(when),任何地方(where),使用任何工具(what)都能通过.NET的服务获得网络上的任何信息. .NET优势: 1.提供了一个面向对象的编程环境,完全支持面向对 ...
- 关于min-height:100%的解决办法
前几天碰到一个问题,在用bs和jq2.2.0开发时,min-height设为100%在firefox和ie下没有起作用,先用css改了一下,但是min-height虽然是奏效了,但同时出现了其他css ...
- java_dom4j解析xml
package forRQ; import java.io.File;import java.net.MalformedURLException;import java.util.Iterator;i ...
- Nexus3.0搭建私服上传JAR包 Windows10
背景 近期换了一个项目组,用的是公司自研产品,涉及到很多内部JAR包引用,版本号很多,每次更新都是产品部给出jar包,项目组成员各自复制一套本地替换,来了新人各种安装配置,复杂度太高,这不,我一来,又 ...
- AJPFX关于TreeSet集合的介绍
需求:键盘录入5个学生信息(姓名,语文成绩,数学成绩,英语成绩),按照总分从高到低输出到控制台.分析:1.创建键盘录入对象: 2.创建TreeSet集合,使用匿名内部类实现Compa ...
- Spark学习之Spark Streaming(9)
Spark学习之Spark Streaming(9) 1. Spark Streaming允许用户使用一套和批处理非常接近的API来编写流式计算应用,这就可以大量重用批处理应用的技术甚至代码. 2. ...