一、初始化一个npm包

  1.新建一个文件夹(名称随意,建议和报名一致),输入命令 :npm init -y

会自动生成一个包的说明文件 package.json如下(本文以scroll-antd-table为例):

{
"name": "scroll-antd-table",//包的名称用于别人 npm install xxxx的时候使用
"version": "1.0.0",//包的版本号
"description": "",//包的描述信息
"main": "index.js",//包的主入口文件,默认index.js根据自己的实际情况修改,下文会讲到
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [], //关键词,有助于别人在npm search的时候找到这个包
"author": "",//作者信息
"license": "ISC",//许可证类型,表明使用权利和限制
}

  2,修改package.json文件

  main:“dist/index.js”  //main属性是告诉别人这个包的最终文件是在dist/index.js里面  

  完善包的其他信息

二、创建包的内容代码

新建一个index.js文件输入要做的组件的内容(scroll-antd-table示例仅供参考)

这里要安装下自己引用的第三方包antd,npm -i antd react -D

import React from "react"
import { Table } from "antd" export default function (props) {
return (
<div >
<Table {...props} />
</div>
)
}

三 打包项目

  1 安装webpack和babel    npm i webpack webpack-cli babel -D   OR   yarn add webpack webpack-cli babel -D

  2  新建 webpack.config.js 文件

module.exports = {
entry: './index.js',
output: {
path: __dirname + '/dist',
filename: "bundle.js",
libraryTarget: "umd",
library: 'scroll-antd-table',
},
externals: {
'react': 'react',
'react-dom': 'react-dom',
'antd': 'antd'
},
mode: "production",
module: {
rules: [
{
test: /(\.js|\.jsx)$/,
use: {
loader: 'babel-loader'
},
exclude: '/node-modules/'
}
]
},
}

 3 新建 .babelrc 文件

{
"presets": [
"@babel/preset-env",
"@babel/preset-react"
]
}

4 执行 npm run build  生成打包的 dist/bundle.js 文件

四.本地测试

  开发完成想要需要现在本地验证一下怎们操作呢?

 1. 在npm包项目目录下执行npm link  ,这样npm 模块项目就会注册在在本地全局中了

 2. 新建一个验证项目可以用create-react-app, 创建好后,执行 npm link 包名 (模块package.json 中的name)

3. 如果这样就启动项目的话会报如下的错误(如果模块中引用了react )

Invalid hook call. Hooks can only be called inside of the body of a function component. This could happen for one of the following reasons:
1. You might have mismatching versions of React and the renderer (such as React DOM)
2. You might be breaking the Rules of Hooks
3. You might have more than one copy of React in the same app

这是因为在验证项目中和在模块包中都引用了react 导致了 3. You might have more than one copy of React in the same app

解决办法是

  1.在验证项目的目录下 执行   cd node_modules/react && npm link

  2.在模块包项目目录下执行    npm link react

  3.重新启动下验证项目即可

    解除关联引用可以使用 npm unlink  [包名]

五.发布模块包

  1.  登录 npm官网 注册账户 ,顺便搜一搜有没有和你的包名(package.json中的name)重复的模块

    2.  在npm模块包目录下运行 npm login 依次输入用户名,密码和邮箱

    3.  执行 npm publish

   注意:必需用 npm的原始镜像 如果修改过,要改一下 npm config set registry https://registry.npmjs.org/

4. 发布成功后到官网上搜索就能看到自己的项目了,

      在其他项目中 npm -i 包名 -S  就能成功引用使用了

     六 升级和删除

  1.升级更新包

     1.1修改好代码内容后重新 npm  run build 打包项目

     1.2  执行 npm version patch 更新包的版本(package.json 文件中的version 会自动增加,也可以手动修改)

     1.3  执行  npm publish

     2.删除npm 包

1.1  删除指定版本 npm unpublish 包名@版本号

    1.2  彻底删除整个包 npm unpublish 包名 --force

从0开始用webpack开发antd,react组件库npm包并发布的更多相关文章

  1. 使用dumi生成react组件库文档并发布到github pages

    周末两天玩了下号称西湖区东半球最牛逼的react文档站点生成工具dumi,顺带结合github pages生成了react-uni-comps文档站, 一套弄下来,感觉真香,现在还只是浅尝,高级的特性 ...

  2. jquery插件模式开发和react组件开发之间的异同

    jquery插件模式开发和react组件开发之间的异同

  3. 如何快速构建React组件库

    前言 俗话说:"麻雀虽小,五脏俱全",搭建一个组件库,知之非难,行之不易,涉及到的技术方方面面,犹如海面风平浪静,实则暗礁险滩,处处惊险- 目前团队内已经有较为成熟的 Vue 技术 ...

  4. React 组件库框架搭建

    前言 公司业务积累了一定程度,需要搭建自己的组件库,有了组件库,整个团队开发效率会提高恨多. 做组件库需要提供开发调试环境,和组件文档的展示,调研了几个比较主流的方案,如下: docz 配置简单,功能 ...

  5. 七个不可错过的React组件库与开发框架

    React是如今最火爆的前端技术,而React最棒的一个特点就是有大量功能丰富的组件库和开发框架可用.从按钮到卷轴到工具条,应有尽有,而且这些组件可以各行其是,也可以组装成复杂的UI,你也可以把UI分 ...

  6. 如何开发一个npm包并发布

    一.安装nodejs 不多说了,网上教程多得是 二.创建自己的npm包 目录结构 npm-test a.js b.js package.json 开发 为了简单便于理解,就开发一个简单地hello程序 ...

  7. 如何开发一个npm包并发布到npm中央仓库

    转自: https://liaolongdong.com/2019/01/24/publish-public-npm.html 如何开发一个npm包并发布到npm中央仓库需求背景:平时在项目工作中可能 ...

  8. 如何从0开发一个Vue组件库并发布到npm

    1.新建文件夹在终端打开执行 npm init -y 生成package.json如下,注意如果要发布到npm,name不能有下划线,大写字母等 { "name": "v ...

  9. React组件库

    图表组件库:Recharts(React和D3构建的图表库) UI组件库:react-bootstrap

随机推荐

  1. 数据库中间件ShardingSphere-Proxy(一)

    1.现实中的问题 我们知道数据库的数据,基本80%的业务是查询,20%的业务涵盖了增删改,经过长期的业务变更和积累数据库的数据到达了一定的数量之后,直接影响的是用户与系统的交互,查询时的速度,插入数据 ...

  2. 记-Golang获取本机IP及快速搭建局域FTP

    1 package main 2 3 import ( 4 "fmt" 5 "net" 6 "net/http" 7 "strin ...

  3. Nature | 易基因DNA甲基化测序助力人多能干细胞向胚胎全能8细胞的人工诱导

    北京时间2022年3月22日凌晨,<Nature>期刊在线刊登了由中国科学院广州生物医学与健康研究所等单位牵头,深圳市易基因科技有限公司.中国科学技术大学等单位参与,应用人多能干细胞向胚胎 ...

  4. TreeMap与TreeSet的源码分析

    1.TreeMap源码 1.属性部分: private final Comparator<? super K> comparator;//比较器 private transient Ent ...

  5. JavaScript中call如何使用?

    一句话概括:call是函数才能调用的方法.作用是改变属性环境.有点绕,举个例子. 此处代码是在window环境下声明的变量和函数. var name='王延朋'; var age=18; var ex ...

  6. 本地连接MySQL云服务器步骤与解决方案

    云服务器:aliyun MySQL 版本:mysql8 第一步首先,检查云服务器的 网络与安全 -> 安全组 是否开放了(MySQL)3306端口 第二步,登陆云服务器上的MySQL,检查需要远 ...

  7. C++ | 虚表的写入时机

    虚表 在C++的多态机制中,使用了 virtual 关键字声明的函数称之为虚函数,每个有虚函数的类或者虚继承的子类,编译器都会为它生成一个虚拟函数表(简称:虚表,以下用 vftable表示),表中的每 ...

  8. web前端教程《每日一题》(1-99)完结

    第1期(2016年4月6日): (1)js中关闭当前窗口的方法是:window.close(); 第2期(2016年4月7日): (1)js中使字符串中的字符变为小写的方法是:toLowerCase方 ...

  9. 五款轻量型bug管理工具横向测评

    五款轻量型bug管理工具横向测评 最近正在使用的本地bug管理软件又出问题了,已经记不清这是第几次了,每次出现问题都要耗费大量的时间精力去网上寻找解决方案,劳心劳力.为了避免再次出现这样的情况,我决定 ...

  10. 老版本的Spring应用该如何应对CVE-2022-22965漏洞?

    昨天,在发布了<Spring官宣承认网传大漏洞,并提供解决方案>之后.群里就有几个小伙伴问了这样的问题:我们的Spring版本比较老,该怎么办?这是一个好问题,所以DD今天单独拿出来说说. ...