vue全局提示框组件

一. 先写一个普通的vue组件

文件位置 /src/toast/toast.vue

二. 在我们需要使用的页面引入组件,方便看效果和错误

三. 实现动态加载组件

我们先在 /src/toast/ 目录下面,新建一个index.js, 然后在index.js里面,敲入以下代码

文件位置 /src/toast/index.js

 

import vue from 'vue'// 这里就是我们刚刚创建的那个静态组件
import toastComponent from './toast.vue'// 返回一个 扩展实例构造器
const ToastConstructor = vue.extend(toastComponent)// 定义弹出组件的函数 接收2个参数, 要显示的文本 和 显示时间
function showToast(text, duration = 2000) {// 实例化一个 toast.vueconst toastDom = new ToastConstructor({el: document.createElement('div'),data() {return {text:text,show:true}}})// 把 实例化的 toast.vue 添加到 body 里document.body.appendChild(toastDom.$el)// 过了 duration 时间后隐藏setTimeout(() => {toastDom.show = false} ,duration)
}// 注册为全局组件的函数
function registryToast() {// 将组件注册到 vue 的 原型链里去,// 这样就可以在所有 vue 的实例里面使用 this.$toast()vue.prototype.$toast = showToast
}export default registryToast

四.在vue的入口文件(脚手架生成的话是./src/main.js) 注册一下组件

文件位置 /src/main.js

import toastRegistry from './toast/index'// 这里也可以直接执行 toastRegistry()
Vue.use(toastRegistry)

五.修改第二步

六. 优化

缺少一个动画,现在的弹出和隐藏都很生硬

我们再对 toast/index.js 里的showToast函数稍微做一下修改(有注释的地方是有改动的)

文件位置 /src/toast/index.js

function showToast(text, duration = 2000) {const toastDom = new ToastConstructor({el: document.createElement('div'),data() {return {text:text,showWrap:true,    // 是否显示组件showContent:true  // 作用:在隐藏组件之前,显示隐藏动画}}})document.body.appendChild(toastDom.$el)// 提前 250ms 执行淡出动画(因为我们再css里面设置的隐藏动画持续是250ms)setTimeout(() => {toastDom.showContent = false} ,duration - 1250)// 过了 duration 时间后隐藏整个组件setTimeout(() => {toastDom.showWrap = false} ,duration)
}

 

然后,再修改一下toast.vue的样式

文件位置 /src/toast/toast.vue

总结

看了几篇唯觉得这篇简单易懂,搬运过来记录学习,并分享给大家

  1. vue.extend 函数可以生成一个 组件构造器 可以用这个函数构造出一个 vue组件实例
  2. 可以用 document.body.appendChild() 动态的把组件加到 body里面去
  3. vue.prototype.$toast = showToast 可以在全局注册组件
  4. 显示动画比较简单,隐藏动画必须要在隐藏之前预留足够的动画执行时间


原文链接:感谢作者,遂附原文链接

 


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部