封装vue插件并发布到npm详细步骤

3 篇文章 0 订阅

前言

平常使用Vue开发时,一个项目中多个地方需要用到的相同组件通常我们会封装为一个公共组件,但是如果项目不同我们也需要这个组件,那就需要复制一份公共组件代码到新项目,一个还好,如果是多个组件,这样就稍显麻烦了。
所以我们可以将封装好的组件打包发布至npm,就可以像element ui ant-design-vue这些ui组件库一样通过npm命令下载使用了

一、准备

  • 需要封装vue组件,所以我们新建一个vue项目
vue create wq-clock

router vuex 都不需要, less/sass可以选一个, 这个项目我选用的less

二、封装

1. 文件结构

(1). 新建package文件夹, 存放组件。

  • 路径: src/package

(2). 该文件下存放我们封装的组件,我们有时可能需要封装多个组件

  • 路径: src/package/wqButton/index.vue
  • 路径:src/package/wqClock/index.vue

(3). 还需要一个js文件在全局注册封装的组件,以供引入此插件的项目所有组件可使用

  • 路径:src/package/index.js

在这里插入图片描述

2. 组件代码

至于封装什么组件,这个全看自己了,我刚好在做一个大屏项目需要用到一个展示当前日期时间的一个组件,但dataV组件库没有这样的组件,所以需要自己写一个。

路径: src/package/wqClock/index.vue

<template>
  <div id="clock">
    <div class="box" :style="{ color: textColor }">
      <span class="date">{{ date }}</span>
      <span class="time">{{ time }}</span>
    </div>
  </div>
</template>
<script>
export default {
  name: "wqClock",
  props: {
    textColor: {
      type: String,
      default: "#2cf3fb",
    },
  },
  data() {
    return {
      timer: null,
      date: "",
      time: "",
    };
  },
  created() {
    this.updateTime();
  },
  mounted() {
    this.timer = setInterval(() => {
      this.updateTime();
    }, 1000);
  },
  methods: {
    updateTime() {
      let date = new Date();
      let sDate = "-";
      let sTime = ":";

      let YYYY = formatHandle(date.getFullYear());
      let MM = formatHandle(date.getMonth() + 1);
      let DD = formatHandle(date.getDate());

      let hh = formatHandle(date.getHours());
      let mm = formatHandle(date.getMinutes());
      let ss = formatHandle(date.getSeconds());

      let w = ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"];
      let week = w[date.getDay()];

      this.date = YYYY + sDate + MM + sDate + DD + ` ${week}`;
      this.time = hh + sTime + mm + sTime + ss;

      function formatHandle(value) {
        if (value >= 0 && value < 10) return "0" + value;
        else return value;
      }
    },
  },
  beforeDestroy() {
    clearInterval(this.timer);
  },
};
</script>
<style lang="less" scoped>
#clock {
  font-family: "Share Tech Mono", monospace;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  .box {
    text-align: center;
    .date {
      font-size: 28px;
      letter-spacing: 2px;
      display: inline-block;
      padding-bottom: 10px;
    }
    .time {
      letter-spacing: 6px;
      font-size: 80px;
    }
  }
}
</style>

封装时可在App.vue文件中引入测试

3. 注册全局组件

使用Vue提供的install方法,这个方法会在使用Vue.use(plugin)时被调用,这样就能让我们需要导出的组件注册到全局, 就可以在任意组件中像使用子组件一样直接使用导出的组件

  • 路径:src/package/index.js
import wqButton from './wqButton/index.vue'
import wqClock from './wqClock/index.vue'

const comArr = [wqButton, wqClock];

// 注册组件
export default install = (Vue) => {
    comArr.forEach(item => {
        Vue.component(item.name, item)  // item.name就是引入组件中的name属性,所以每个组件都需要name
    })
};

三、发布

1. 打包

配置打包命令package,当然也可以自己取。就像我把serve改为wq一样

  • 路径: package.json
"scripts": {
    "wq": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "package": "vue-cli-service build --target lib ./src/package/index.js --name wq-clock --dest wq-clock"
  },

--target lib 指定打包的目录
--name 打包后的文件名
--dest 打包后的文件夹名称

执行打包命令

npm run package

打包完成后会在src同级产生一个wq-clock文件夹,也就是打包命令中配置的--dest属性值

在这里插入图片描述

2. 配置package.json文件

  • 初始化一个package.json文件

cd切换到wq-clock目录执行初始化package.json文件目录

npm init -y

此时wq-clock目录会初始化一个package.json文件,j具体配置如下

  • 路径:wq-clock/package.json
{
    "name": "wq-clock",  // 发布的包名,发布线上后,可以通过 npm install 该名称 来引用该包
    "version": "0.0.3",  // 版本号
    "description": "",  // 描述
    "main": "wq-clock.common.js",  // // 打包后的入口文件,若不配置,则在其他项目中就无法使用import xx from '包名'来引入组件,只能以包名作为起点来指定相对路径
    "scripts": {  // 运行命令
        "test": "echo \"Error: no test specified\" && exit 1"
    },
    "keywords": [  // 关键词,可以通过npm搜索你填写的关键词找到你的包
        "时间",
        "时钟"
    ],
    "author": "wenqingkey",  // 作者
    "private": false,  // 是否设为私有包
    "license": "ISC"  // 代码授权许可
}

提示: 如果复制上面的json文件内容,需要删除注释,因为json文件不能有注释

3. 注册npm账号

  • 有npm账号可跳过此步

可去npm官网注册: https://www.npmjs.com
也可以通过命令行注册

首先得将npm镜像源切换为官方的源,大部分人的镜像源可能为淘宝镜像源,其他的也不行,想发布就得切换为npm官方镜像源

npm config set registry=https://registry.npmjs.org

注册

npm adduser

依次填入账号、密码、邮箱, 填写完成后邮箱会收到一个npm发的一次性密码(也就是验证码) 再次填入即可,如果还未填写就报错,多半是得需要墙

4. 登录npm账号

切换到wq-clock目录,也就是你的包文件夹目录

执行命令

npm login

依次输入账号、密码、邮箱以及收到的一次性密码,如果输入邮箱之后一直卡在那里不动的话可以试试npm login -d

5. 发布npm插件

发布之前可去npm官网搜索一下你这个包名是否跟里面的包有重名的,有的话不能发,也可以使用npm i 你的包名测试

执行命令

npm publish

在这里插入图片描述
这是发布成功的效果,未成功请根据提示做相应的修改

  • 发布成功后可以在npm官网搜索查看自己发的包

在这里插入图片描述

四、使用

  • ant design vue element ui 这些组件库一样, 在需要使用该插件的项目引入

1. 安装插件

npm i wq-clock

2. 引入注册

  • 路径: main.js
import Vue from 'vue'
import WqClock from 'wq-clock';
import "../node_modules/wq-clock/wq-clock.css";
Vue.use(WqClock);

3. 组件使用

为了方便我直接在App.vue中使用

<template>
  <div id="app">
    <div class="wq_clock">
      <wq-clock></wq-clock>
    </div>
  </div>
</template>

<script>
export default {
  name: "App",
};
</script>

<style lang="less">
* {
  margin: 0;
  padding: 0;
}
body {
  width: 100vw;
  height: 100vh;
}

.wq_clock {
  width: 600px;
  height: 300px;
  background: #000;
}
</style>

4. 效果

在这里插入图片描述

5. 传参效果

因为我封装的时候给了个字体颜色的参数,所以可以传入一个textColor

<wq-clock textColor="#fff"></wq-clock>

在这里插入图片描述

到此基本的vue插件封装与发布就大功告成了

  • 6
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 8
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

温情key

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值