React 图标库发布到 npm 仓库

将搭建的 React 图标库发布到 npm 仓库需要经过一系列步骤,包括配置 package.json、构建代码、注册 npm 账号、测试和发布。以下是详细流程:


1. 准备工作

(1) 确保项目结构完整

图标库的典型结构(以 Rollup 构建为例):

my-react-icons/
├── dist/               # 构建输出目录(由 Rollup 生成)
├── src/                # 源代码
│   ├── icons/          # 图标组件
│   └── index.js        # 统一导出
├── rollup.config.js    # Rollup 配置
├── package.json        # 项目配置
└── README.md           # 使用文档
(2) 检查 package.json 关键字段
{"name": "my-react-icons",      // 包名(确保唯一性,先在 npm 搜索是否重名)"version": "1.0.0",           // 版本号(遵循语义化版本规范)"description": "A custom React icon library","main": "dist/index.js",       // CommonJS 入口文件"module": "dist/index.esm.js", // ES Module 入口文件(支持 Tree Shaking)"files": ["dist"],            // 指定发布到 npm 的目录"scripts": {"build": "rollup -c",       // 构建命令"prepublishOnly": "npm run build" // 发布前自动构建},"peerDependencies": {         // 声明依赖的 React 版本"react": ">=16.8.0","react-dom": ">=16.8.0"},"keywords": ["react", "icons", "svg"],"author": "Your Name","license": "MIT"
}

2. 注册 npm 账号

(1) 注册账号
  • 访问 npm 官网 注册账号。
  • 如果已有账号,跳过此步骤。
(2) 本地登录 npm

在项目根目录运行:

npm login

按提示输入:

  • Username: 你的 npm 用户名
  • Password: 密码
  • Email: 注册邮箱(需验证)

登录成功后会显示:
Logged in as <your-username> on https://registry.npmjs.org/


3. 构建代码

运行构建命令生成 dist 目录:

npm run build

确保 dist 目录下包含:

  • index.js(CommonJS 格式)
  • index.esm.js(ES Module 格式)

4. 测试本地包

(1) 本地模拟发布

在项目根目录运行:

npm pack

生成一个 .tgz 文件(如 my-react-icons-1.0.0.tgz),在其他项目中安装测试:

cd ../another-project
npm install ../my-react-icons/my-react-icons-1.0.0.tgz

测试是否正常使用:

import { Home } from 'my-react-icons';
(2) 使用 npm link(可选)

在图标库目录运行:

npm link

在测试项目目录运行:

npm link my-react-icons

5. 正式发布到 npm

(1) 检查 npm 源

确保使用的是官方源:

npm config get registry
# 应该是 https://registry.npmjs.org/

如果使用淘宝镜像,需切换:

npm config set registry https://registry.npmjs.org/
(2) 发布包

在项目根目录运行:

npm publish

成功后会显示:
+ my-react-icons@1.0.0


6. 发布后验证

  1. 访问 https://www.npmjs.com/package/my-react-icons,查看包是否已上线。
  2. 在其他项目中安装测试:
    npm install my-react-icons
    

7. 更新版本

修改代码后,按语义化版本规则更新版本号:

  • 补丁版本(修复 bug): npm version patch1.0.1
  • 次要版本(新增功能): npm version minor1.1.0
  • 主要版本(重大变更): npm version major2.0.0

重新发布:

npm publish

8. 常见问题解决

(1) 包名冲突

错误提示:You do not have permission to publish "my-react-icons"
解决:修改 package.json 中的 name 为唯一名称(如 @yourusername/my-react-icons)。

(2) 未验证邮箱

错误提示:npm ERR! 403 Forbidden - PUT https://registry.npmjs.org/my-react-icons - You must verify your email before publishing a package
解决:登录 npm 官网验证邮箱。

(3) 重复发布

错误提示:Cannot publish over existing version
解决:更新版本号后再发布。


9. 高级配置(可选)

(1) 添加 TypeScript 支持
  1. 创建 index.d.ts 类型声明文件:
    // src/types.d.ts
    import * as React from 'react';
    export interface IconProps extends React.SVGProps<SVGSVGElement> {size?: number | string;color?: string;
    }
    export declare const Home: React.FC<IconProps>;
    
  2. package.json 中添加:
    "types": "dist/types.d.ts"
    
(2) 自动化构建与发布

使用 GitHub Actions 自动发布(示例配置 .github/workflows/publish.yml):

name: Publish to npm
on:push:tags:- 'v*'
jobs:publish:runs-on: ubuntu-lateststeps:- uses: actions/checkout@v4- uses: actions/setup-node@v4with:node-version: 20registry-url: https://registry.npmjs.org/- run: npm install- run: npm publishenv:NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} # 在 npm 获取 token 并添加到 GitHub Secrets

总结

  1. 配置 package.json:确保 nameversionmain/module 字段正确。
  2. 登录 npmnpm login
  3. 构建代码npm run build
  4. 测试本地包npm packnpm link
  5. 发布npm publish
  6. 更新维护:通过 npm versionnpm publish 迭代版本。

完成以上步骤后,你的 React 图标库就可以被全球开发者通过 npm install 使用了!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/91148.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/91148.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java学习第八十四部分——HttpClient

目录 一、前言介绍 二、主要特点 三、功能用法 四、应用场景 五、最佳实践 六、总结归纳 一、前言介绍 HttpClient 是一个用于发送 HTTP 请求和接收 HTTP 响应的客户端库&#xff0c;广泛应用于 Web 开发、API 调用、微服务通信等场景。 二、主要特点 支持多种HTTP方…

学习笔记-中华心法问答系统的性能提升

1.简介本周主要任务是自行查找文献&#xff0c;针对源代码进行性能提升&#xff0c;主要包括三个方面&#xff1a;预处理&#xff1a;分词、关键词提取、词向量生成&#xff1b;文本分析&#xff1a;从多个关键词的词向量&#xff0c;如何到一句话的语义理解&#xff1b;问题分…

Python爬虫03_Requests破解百度翻译

爬取百度翻译页面信息 以POST方法发送JSON数据&#xff0c;爬取响应信息&#xff0c;并且需要对响应信息对象类型进行区分。 import requests import json#1.指定url post_url https://fanyi.baidu.com/sug#2.进行UA封装 headers {User-Agent:Mozilla/5.0 (Windows NT 10.0; …

【C++进阶】第8课—红黑树封装map和set

文章目录1. map和set的源码及框架分析2. 模拟实现map和set2.1 实现可以复用红黑树的框架&#xff0c;支持insert操作2.2 实现迭代器iterator2.2.1 实现迭代器2.2.2 实现迭代器 - -2.2.3 解决key不能修改的问题2.2.4 重载operator[ ]3. 完整代码3.1 红黑树头文件RBTree.h3.2 mym…

【机器学习深度学习】DeepSpeed框架:高效分布式训练的开源利器

目录 前言 一、DeepSpeed 简介 1.1 定位与目标 1.2 集成生态 二、核心技术解析 2.1 ZeRO&#xff08;Zero Redundancy Optimizer&#xff09; 2.2 显存优化技术 2.3 推理优化与通信机制 三、DeepSpeed 的优势与特性总结 四、 典型应用场景 &#x1f9e0; 大模型训练…

从视觉到现实:掌握计算机视觉技术学习路线的十大步骤

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;【14后&#x1f60a;///计算机爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】今日分享关于计算机视觉技术学习路线方面的相关内容…

DeepSeek MoE 技术解析:模型架构、通信优化与负载均衡

1. MoE 简介 MoE&#xff08;Mixed Expert Models&#xff09;&#xff0c;混合专家模型。在 Transformer 的 FFN 中&#xff0c;有一个重要的观察是&#xff0c;其计算过程中的神经元激活是非常稀疏的&#xff0c;在一次计算中只有 90%的输入激活不到 5%的神经元&#xff0c;…

【Linux】pthread学习笔记

1. 线程基础(1) 线程创建与终止#include <pthread.h> // 创建线程 int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine)(void*), void *arg); // 终止当前线程 void pthread_exit(void *retval); // 等待线程结束 int pthread_joi…

p5.js 从零开始创建 3D 模型,createModel入门指南

点赞 关注 收藏 学会了 如果你已经开始探索 p5.js 的 3D 世界&#xff0c;那么createModel()这个 API 绝对是你需要掌握的强大工具。它允许你创建自定义的 3D 几何模型&#xff0c;为你的创意提供无限可能。 什么是 createModel ()&#xff1f; createModel() 用于从一个…

react 的 useTransition 、useDeferredValue

useTransition 用于 管理状态更新的过渡&#xff08;pending&#xff09;状态&#xff0c;避免因高优先级任务&#xff08;如用户输入&#xff09;被低优先级任务&#xff08;如数据获取或复杂计算&#xff09;阻塞而导致的界面卡顿。 它特别适用于&#xff0c;需要 区分紧急更…

Unity的GameObject.Instantiate的使用

在Unity游戏引擎中&#xff0c;GameObject.Instantiate 是一个核心方法&#xff0c;用于在运行时动态创建游戏对象的副本。它常用于实例化预制体&#xff08;Prefab&#xff09;&#xff0c;例如生成敌人、子弹或场景元素。以下是其使用方法的详细说明&#xff0c;包括语法、参…

【CSS】盒子类型

CSS盒子模型是网页布局的核心基础&#xff0c;每个HTML元素都被视为一个矩形盒子&#xff0c;由​​内容&#xff08;Content&#xff09;、内边距&#xff08;Padding&#xff09;、边框&#xff08;Border&#xff09;、外边距&#xff08;Margin&#xff09;​​四部分组成。…

《嵌入式C语言笔记(十五):字符串操作与多维指针深度解析》

1.字符串与指针安全操作核心函数与陷阱函数功能安全替代功能strcpy字符串拷贝strncpy复制前n个&#xff0c;最多strlen个&#xff0c;超出有效长度&#xff0c;按原样复制strcat字符串拼接strncatdest只连接src的前n个&#xff0c;如果n超过有效长度&#xff0c;按原样链接strc…

每日学习笔记记录(分享更新版-凌乱)

函数和变量都需要满足&#xff1a;先声明后使用&#xff08;重要&#xff09;在 函数的声明中&#xff0c;形参的名字可以省略函数的定义是一种特殊的是声明&#xff0c;比声明更加强大&#xff1b;函数使用前必须进行声明&#xff0c;但不必要声明具体定义.h——函数的声明.c—…

Windows提权(MS09-012 巴西烤肉)

演示环境&#xff1a;windows-2003前提&#xff1a;提权的前提条件是拿到服务器的webshell演示以iis的中间件解析漏洞为例&#xff08;test.asp;.jpg&#xff09; Windows提权拿到webshell之后&#xff0c;使用菜刀&#xff0c;蚁剑&#xff0c;冰蝎或者哥斯拉连接上服务器&…

常见依赖于TCP/IP的应用层协议

Protocol 协议 Acronym 缩写 Port 端口 Description 描述 Telnet Telnet 23 Remote login service 远程登录服务 Secure Shell SSH 22 Secure remote login service 安全远程登录服务 Simple Network Management Protocol 简单网络管理协议 SNMP 161-162 Manage network d…

XML Schema 指示器:全面解析与深度应用

XML Schema 指示器:全面解析与深度应用 引言 XML Schema 是一种用于定义 XML 文档结构的语言,它为 XML 文档提供了严格的框架,以确保数据的准确性和一致性。在本文中,我们将深入探讨 XML Schema 的基本概念、关键特性、指示器的作用以及其实际应用。 XML Schema 的基本概…

13、select_points_object_model_3d解析

名字 select_points_object_model_3d- 将阈值应用于 3D 对象模型的属性。 签名 select_points_object_model_3d( : : ObjectModel3D, Attrib,

ThinkPHP6.1+Ratchet库 搭建websocket服务

Ratchet 是一个基于 ReactPHP 的 PHP WebSocket 库&#xff0c;无需依赖 Swoole 扩展。以下是实现步骤&#xff1a;首先安装 Ratchet&#xff1a;composer require cboden/ratchet创建 WebSocket 处理类&#xff1a;<?php /*** websocket处理类* DateTime 2025/7/28 10:38…

智慧工地系统:科技如何重塑建筑现场?

前几天路过一个正在施工的楼盘&#xff0c;看到现场虽然机器轰鸣&#xff0c;但秩序井然&#xff0c;工人们佩戴着设备&#xff0c;指挥塔上闪烁着指示灯&#xff0c;和印象中那种尘土飞扬、杂乱无章的工地景象完全不同。当时就感慨&#xff0c;现在工地也“智慧”起来了。后来…