Vue 封装 自定义toast 插件并随处调用

toast插件功能说明

1、展示一条提示消息,显示3s 中或者其他时间后消失
2、消息为自定义消息,展示多条消息,展示最新的消息
3、可关闭当前展示的消息

开发说明

目录结构

首先在vue 项目中src 目录下,创建plugins目录,存放插件内容

── plugins
│   │   └── ToastMessage
│   │       ├── index.js
│   │       └── index.vue

.vue组件内容

承载组件的内容,在@/plugins/ToastMessage/index.vue文件里
我需要的内容不多,message 和show 来分别控制展示内容和展示与否

<template>
  <div class="toastMessageBox" v-show="show">{{message}}</div>
</template>

<script>
import {mapState} from 'vuex'
export default {
  name: 'toastMessage',
  data () {
    return {
      message: '',
      show: false
    }
  }
}
</script>

<style lang='less' scoped>
.toastMessageBox{
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background-color: rgba(0, 0, 0, 0.8);
  color: #fff;
  padding: 8px;
  font-size: 16px;
  border-radius: 8px;
  text-align: center;
}
</style>

组件输出为插件

通常,将上面的组件直接引入到父组件,这为组件的使用,如果是插件,需要将改组件export 并extend在Vue 实例上。
将Vue 和上面的 组件引入进来

import Vue from 'vue'
import vueToastMessage from './index.vue'

将组件挂到Vue上,声明变量构造函数的变量、定时器的变量

let ToastTem = Vue.extend(vueToastMessage)
let instance
let timer = null

生成构造函数,挂载到dom元素上,避免重复生成多个构造函数,需判断是否已经存在;
判断是否正在展示中,清空定时器,将展示的内容赋值为新内容;
通过定时器来控制展示的时长,如果未传参数,默认为3s;

let toastMessage = (options) => {
  if (!instance) {
    instance = new ToastTem()
    instance.vm = instance.$mount()
    document.body.appendChild(instance.vm.$el)
  }
  console.log(options)
  if (timer) {
    clearTimeout(timer)
    timer = null
    instance.show = false
    instance.message = ''
  }
  let time = 3000
  if (typeof options === 'string') {
    instance.message = options
  } else if (typeof options === 'object') {
    let {message, time} = options
    instance.message = message
    time = time || 3000
  } else {
    return
  }
  instance.show = true
  timer = setTimeout(() => {
    instance.show = false
    clearTimeout(timer)
    timer = null
    instance.message = ''
  }, time)
}

关闭toast

toastMessage.close = () => {
  if (timer) {
    clearTimeout(timer)
    timer = null
    instance.show = false
    instance.message = ''
  }
}

以上直接在末尾export default toastMessage,即可在元素中调用,调用方法:

export default toastMessage
局部使用
import toastMessage from '@/plugins/ToastMessage'
toastMessage({message: '123', time: 3000})
挂载到全局

需要在export default toastMessageinstall,挂载到prototype

toastMessage.install = (Vue) => {
  Vue.prototype.$toastMessage = toastMessage
}

在main.js 中引入

import toastMessage from '@/plugins/ToastMessage' // message 提示消息插件
Vue.use(toastMessage)
在组件中使用
this.$toastMessage({message: '33333', time: 3000})

完整的@/plugins/ToastMessage/index.js 文件内容如下:

import Vue from 'vue'
import vueToastMessage from './index.vue'
let ToastTem = Vue.extend(vueToastMessage)
let instance
let timer = null
let toastMessage = (options) => {
  if (!instance) {
    instance = new ToastTem()
    instance.vm = instance.$mount()
    document.body.appendChild(instance.vm.$el)
  }
  console.log(options)
  if (timer) {
    clearTimeout(timer)
    timer = null
    instance.show = false
    instance.message = ''
  }
  let time = 3000
  if (typeof options === 'string') {
    instance.message = options
  } else if (typeof options === 'object') {
    let {message, time} = options
    instance.message = message
    time = time || 3000
  } else {
    return
  }
  instance.show = true
  timer = setTimeout(() => {
    instance.show = false
    clearTimeout(timer)
    timer = null
    instance.message = ''
  }, time)
}
toastMessage.close = () => {
  if (timer) {
    clearTimeout(timer)
    timer = null
    instance.show = false
    instance.message = ''
  }
}
toastMessage.install = (Vue) => {
  console.log('install--------toastMessage')
  Vue.prototype.$toastMessage = toastMessage
}
export default toastMessage

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    柴东啊阅读 15,876评论 2 140
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    小姜先森o0O阅读 9,603评论 0 72
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    你猜_3214阅读 11,135评论 0 118
  • 基于Vue的一些资料 内容 UI组件 开发框架 实用库 服务端 辅助工具 应用实例 Demo示例 element★...
    尝了又尝阅读 1,171评论 0 1
  • 一、UI组件及框架 element - 饿了么出品的Vue2的web UI工具套件mint-ui - Vue 2的...
    Yin先生阅读 3,031评论 0 33