Vue 组件封装发布 npm 包(2023/03/17)
创始人
2025-05-29 12:22:17
0

Vue 组件封装发布 npm 包(2023/03/17)

文章目录

  • Vue 组件封装发布 npm 包(2023/03/17)
    • 1. 前提条件
    • 2. 准备项目
      • 2.1 创建 Vue 项目
      • 2.2 编写组件
      • 2.3 测试组件
      • 2.4 编写打包入口文件
      • 2.5 编写 Readme
    • 3. 打包发布
      • 3.1 非编译方式(推荐)
      • 3.2 编译方式
    • 4. 测试使用

项目中经常遇到需要组件复用的情况,本文将介绍如何将 Vue 组件封装成 npm 包,并上传到 npm 私有仓库(本文不介绍 npm 私有仓库的搭建,请自行查阅相关资料)。

1. 前提条件

  • npm 私有仓库;
  • nodejs;
  • Vue;

2. 准备项目

2.1 创建 Vue 项目

  1. 通过 vue-cli 创建并初始化 vue2 项目;

    $ vue create app
    
  2. 创建src/packages目录用来存放组件,项目整体目录结构如下;

    app
    ├── README.md
    ├── babel.config.js
    ├── jsconfig.json
    ├── node_modules
    ├── package-lock.json
    ├── package.json
    ├── public
    │   ├── favicon.ico
    │   └── index.html
    ├── src
    │   ├── App.vue
    │   ├── assets
    │   ├── components
    │   ├── packages
    │   └── main.js
    └── vue.config.js
    

2.2 编写组件

此处以简单的 HelloVue 组件为例,新建src/packages/hello-vue/index.vue文件,内容如下:


2.3 测试组件

src/App.vue中引入HelloVue组件测试能否正常使用,内容如下:


2.4 编写打包入口文件

测试通过后,编写打包入口 js 文件,创建src/index.js文件,内容如下:

import HelloVue from "@/packages/hello-vue/index.vue";// 需要打包导出的组件
const components = [HelloVue
];const install = function (Vue) {components.map(component => {Vue.component(component.name, component);});
}if (typeof window !== 'undefined' && window.Vue) {install(window.Vue);
}export default {name: "HelloVue",version: "1.0.0",install
};

2.5 编写 Readme

编写Readme.md文件内容,如插件使用方式等等。

3. 打包发布

3.1 非编译方式(推荐)

使用非编译的方式可以解决src/assets文件夹下静态文件依赖的问题,但无法解决public目录静态文件依赖问题(目前还没找到较好的解决办法)。

  1. 修改package.json文件,修改内容如下:

    {"name": "@zhy/app", // 包名"version": "0.1.0", // 版本号,后续每次更新发布都要修改"private": false, // 必须修改为 false"description": "Hello Vue!", // 包描述"main": "./src/index.js" // 包入口文件
    }
    
  2. 添加.npmignore文件,忽略不需要发布的文件,如配置文件等;

    node_modules/public/src/components
    src/App.vue
    src/main.js.gitignorebabel.config.js
    jsconfig.json
    package-lock.json
    vue.config.js.idea
    
  3. 登录私有仓库,此处笔者仓库地址为http://172.20.2.5:8081/repository/npm-hosted/

    # 根据提示输入用户名密码登录
    $ npm login --registry http://172.20.2.5:8081/repository/npm-hosted/
    
  4. 发布到私有仓库;

    # 发布
    $ npm publish --registry http://172.20.2.5:8081/repository/npm-hosted/# 从私有仓库删除(谨慎操作)
    $ npm unpublish -f --registry http://172.20.2.5:8081/repository/npm-hosted/
    

3.2 编译方式

编译的方式可以对代码进行编译压缩,隐藏源码,但无法解决静态文件依赖的问题。

  1. 修改package.json文件,修改内容如下:

    {"name": "@zhy/app", // 包名"version": "0.1.0", // 版本号,后续每次更新发布都要修改"private": false, // 必须修改为 false"description": "Hello Vue!", // 包描述"main": "./app/app.umd.js", // 包入口文件,对应打包后的目录"scripts": {"serve": "vue-cli-service serve","build": "vue-cli-service build","lint": "vue-cli-service lint",// 新增打包脚本,--name 打包后的名字,--dest 打包后的目录"package": "vue-cli-service build --target lib src/index.js --name app --dest app"}
    }
    
  2. 打包编译;

    # 成功后生成打包目录 app
    $ npm run package
    
  3. 添加.npmignore文件,忽略不需要发布的文件,如配置文件等;

    node_modules/public/
    src/.gitignore
    .npmignorebabel.config.js
    jsconfig.json
    package-lock.json
    vue.config.js.idea
    
  4. 登录私有仓库,此处笔者仓库地址为http://172.20.2.5:8081/repository/npm-hosted/

    # 根据提示输入用户名密码登录
    $ npm login --registry http://172.20.2.5:8081/repository/npm-hosted/
    
  5. 发布到私有仓库;

    # 发布
    $ npm publish --registry http://172.20.2.5:8081/repository/npm-hosted/# 从私有仓库删除(谨慎操作)
    $ npm unpublish -f --registry http://172.20.2.5:8081/repository/npm-hosted/
    

4. 测试使用

  1. 创建并初始化 Vue 项目;

    $ vue create test-app
    
  2. 安装依赖;

    $ npm install @zhy/app --registry http://172.20.2.5:8081/repository/npm-hosted/
    
  3. src/main.js文件中注册插件;

    import HelloVue from '@zhy/app';Vue.use(HelloVue);
    
  4. App.vue中使用插件;

    
    

参考资料:

  • Vue封装组件并发布到npm仓库 - 掘金 (juejin.cn)
  • 封装Vue组件并发布到npm(完美解决组件中的静态文件引用) - 浅笑· - 博客园 (cnblogs.com)
  • Vue封装组件并发布到npm仓库-阿里云开发者社区 (aliyun.com)

相关内容

热门资讯

企业IP打造指南:小公司低成本... 小公司做企业IP,不是为了装门面,而是让客户在没见到你之前,就能通过内容知道你是谁、你解决什么问题、...
官方:赵心童入选世界斯诺克名人... 北京时间5月8日消息,世界斯诺克巡回赛(WST)今日正式公布了2025/26赛季年终奖项及名人堂更新...
小灰熊AI学员王锋:希望能跟上... 35了,老程序员了。 从进入互联网行业到现在,其实已经做了很多年移动端开发。最早那几年,安卓行业发展...
原创 2... 2026年全国两会把稳定房地产市场列为重点工作,政府工作报告明确提出因城施策控增量、去库存、优供给。...
一年翻倍,六年未归——徽商银行... 文:向善财经 今年的港股市场,与A股市场出现了明显的分化。 A股这边,科技板块在AI浪潮中热闹非凡;...
古井贡酒2025:在行业深度调... 以“稳”为底、以“新”为翼。 文/每日财报 杜康 在行业库存高企、价格倒挂的背景下,当多数酒企在为...
好上好8408万收购鼎瑞芯加码... 5月7日晚,好上好(001298.SZ)抛出一份收购公告,拟以8408万元现金收购深圳市鼎瑞芯科技有...
全面大撤离!李嘉诚英国“套现”... 突发,李嘉诚又卖了。 这次,套现了455亿。 金额不少,但更值得关注的是透露着不同寻常的信号。 因为...
油气价格上涨加剧法国一季度贸易... 据新华社,法国海关7日发布的数据显示,受中东局势推高国际油气价格影响,法国今年第一季度贸易逆差扩大至...
昆仑芯启动科创板IPO上市辅导... 5月8日,据证监会官网显示,昆仑芯(北京)科技股份有限公司于2026年5月7日正式启动科创板上市辅导...
贵州茅台酒股份有限公司关于回购... 来源:上海证券报 证券代码:600519 证券简称:贵州茅台 公告编号:临2026-016 贵州茅...
百度昆仑芯启动科创板上市辅导,... 5月8日,证监会官网显示,昆仑芯(北京)科技股份有限公司 (下称“昆仑芯”)于2026年5月7日正式...
滕州信华的承压时刻:罚单、失信... 2026年4月末,滕州信华美元债单日跌近2%,关联方被列“老赖”。半年前,这家AA+城投曾因非市场化...
002808,或被终止上市! 【导读】因触及财务类退市指标,*ST恒久或被终止上市 中国基金报记者 李智 又一A股或被终止上市。 ...
院士团队掌舵,溧阳这家企业已完... 近日,溧阳天目先导电池材料科技有限公司(下称“天目先导”)官宣完成B轮融资,投资方包括知卓创新资本、...
工商银行全新推出“工盈研选”品... 深圳商报·读创客户端记者 詹钰叶 近日,工商银行重磅推出「工盈研选」基金销售服务品牌,以客户盈利为核...
和讯信息胡云龙:逼空走势,周五... 今天市场出现逼空走势,场内投资者因持有筹码而尤为受益。五一前布局的投资者当前收获颇丰。然而,随着上证...
今晚,油价上调! 4月21日国内成品油价格下调以来,国际市场原油价格剧烈震荡,前期大幅上涨后近日有所回落,本次调价的前...
南方东英旗下两倍做多海力士,成... 【导读】南方东英旗下两倍做多海力士,成为全球最大的个股杠杆及反向产品 中国基金报记者 伊万 人工智能...
原创 金... 黄金,这东西从古至今就没离开过中国人的生活。从老辈人压箱底的小黄鱼,到如今年轻人结婚绕不开的“三金”...