博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Vue 封装 自定义toast 插件并随处调用
阅读量:2240 次
发布时间:2019-05-09

本文共 3194 字,大约阅读时间需要 10 分钟。

toast插件功能说明

1、展示一条提示消息,显示3s 中或者其他时间后消失

2、消息为自定义消息,展示多条消息,展示最新的消息
3、可关闭当前展示的消息

开发说明

目录结构

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

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

.vue组件内容

承载组件的内容,在@/plugins/ToastMessage/index.vue文件里

我需要的内容不多,message 和show 来分别控制展示内容和展示与否

组件输出为插件

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

将Vue 和上面的 组件引入进来

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

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

let ToastTem = Vue.extend(vueToastMessage)let instancelet 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 instancelet timer = nulllet 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

转载地址:http://xkhbb.baihongyu.com/

你可能感兴趣的文章
Spring中使用@Transactional注解进行事务管理的时候只有应用到 public 方法才有效
查看>>
springboot整合rabbitmq及rabbitmq的简单入门
查看>>
mysql事务和隔离级别笔记
查看>>
事务的传播属性(有坑点)自调用失效学习笔记
查看>>
REDIS缓存穿透,缓存击穿,缓存雪崩原因+解决方案
查看>>
动态代理实现AOP
查看>>
23种常见的java设计模式
查看>>
ThreadLocal 那点事儿(续集)
查看>>
阳台做成榻榻米 阳台做成书房
查看>>
深入分析java线程池的实现原理
查看>>
mybatis中"#"和"$"的区别
查看>>
Hibernate与MyBatis区别
查看>>
如何禁用Eclipse的Validating
查看>>
据说看完这21个故事的人,30岁前都成了亿万富翁。你是下一个吗?
查看>>
SpringMVC学习笔记2
查看>>
Oracle知识点连载(一)
查看>>
Oracle知识点连载(二)
查看>>
Oracle知识点连载(三)
查看>>
Oracle知识点连载(五)
查看>>
关于三元运算符的类型转换问题
查看>>