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)

相关内容

热门资讯

华熙生物赵燕谈胶原蛋白乱象:科... 21世纪经济报道记者雷晨 北京报道 近年来,重组胶原蛋白成为医美和护肤领域的热门概念,市场宣传中不乏...
富春染织完成董事会选举换届 开... 7月25日晚间,富春染织公告显示,当日,公司2025年第一次临时股东会和富春染织第四届第一次董事会在...
圣湘生物:两款产品取得医疗器械... 每经AI快讯,圣湘生物(SH 688289,收盘价:22.94元)7月27日晚间发布公告称,圣湘生物...
10年期国债收益率升至1.73... 近期债券市场出现显著调整,多重因素交织推动收益率持续上行。权益市场强势表现与大宗商品价格上涨形成合力...
当对手都在做下沉 蜜雪冰城旗下... [ 今年5月,蜜雪集团跟巴西签署40亿元人民币的采购意向大单,其中大多数是咖啡豆。 ] 当星巴克、瑞...
新手必看!股指期货交易规则基础... 股指期货交易规则,看似复杂抽象,实则与我们的日常生活有着奇妙的共通之处。它就像一场精心编排的生活交响...
王登发履新茅台技开公司“一把手... 一则微信公众号发布的信息,披露了茅台集团旗下的技术开发公司“一把手”已换人。 近日,南都湾财社-酒水...
特斯拉机器人V3量产版亮相!马... 快科技7月27日消息,特斯拉的Optimus人形机器人V3量产版终于要来了!马斯克在最近的财报电话会...
原创 中... 在金融全球化的浪潮中,中国资本市场始终勇立潮头,不断探索前行。7月26日,中国资本市场学会成立大会暨...
报告:我国经济增长保持韧性 下... 央广网北京7月27日消息(记者 樊瑞)近日,中国金融四十人论坛(CF40论坛)发布《2025年第二季...
超6300亿元!A股银行“分红... 7月25日,成都银行完成权益分派股权登记,将于7月28日发放现金红利,这标志着A股上市银行2024年...
老铺黄金:2025年上半年单个... 7月27日晚,老铺黄金(HK06181)披露2025年中期业绩预告。预计2025年上半年实现销售业绩...
保险行业2025年上半年回顾与... 今天分享的是:保险行业2025年上半年回顾与未来展望 报告共计:59页 2025年上半年保险行业回顾...
数币App上新!消费者、商户两... 数字人民币试点持续推进,相关数字钱包手机应用程序功能也在优化中。7月21日,北京商报记者注意到,日前...
A股热点迭出,个股连续涨停!资... 近段时间以来A股市场整体走势较为强劲,上周以来在雅江概念集体上行的推动下涨势更为明显,主要指数不同程...
原创 印... 令人惊讶的是,印度人开始反思自身制造业的发展状况。印度经济学家帕纳加利亚指出,印度原本有机会在20年...
首创证券拟赴港上市,“A+H”... 首创证券在A股上市不足三年便启动赴港上市计划。近日,首创证券公告称,公司董事会已审议通过了公司拟发行...
肥东杨大爷要帮“儿子”还钱,银... “儿子”在外借了2万元还不上 “要债人”电话直接打了过来 还?还是不还? 7月6日 肥东县公安局梁园...
A股上周16家上市公司公布并购... 转自:扬子晚报 扬子晚报网7月27日讯(记者 范晓林 薄云峰)近段时间以来,A股市场并购重组活跃度持...
独家|某股份行改动零售业务关键... 在资产端信贷“投不动”(多家行零售信贷增速连续几个季度放缓、更有甚者个贷投放负增长)、负债端存款“定...