以下是封装前端组件并发布至npm仓库的完整步骤指南,结合多个最佳实践和常见问题解决方案:
一、环境准备与项目初始化
-
创建项目结构
• 使用Vue CLI或Create React App初始化项目:vue create my-component-lib # Vue npx create-react-app my-component-lib --template typescript # React
• 调整目录结构(参考element-ui规范):
├── packages/ # 组件源码 ├── examples/ # 示例项目(原src目录) └── vue.config.js/webpack.config.js
-
初始化npm包
cd my-component-lib npm init -y
修改生成的package.json关键字段:
{ "name": "my-ui", // 必须唯一,检查npm官网是否被占用 "version": "1.0.0", "main": "dist/my-ui.umd.min.js", // 打包后的入口文件 "files": ["dist"], // 指定发布目录 "private": false, "scripts": { "build": "vue-cli-service build --target lib ./packages/index.js" } }
二、组件封装开发
Vue组件规范(参考)
-
组件文件结构
packages/ ├── button/ │ ├── src/ │ │ └── button.vue # 组件源码 │ └── index.js # 单组件注册 └── index.js # 全局注册入口
-
全局注册插件
// packages/index.js import Button from &