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
{{text}}
总结
看了几篇唯觉得这篇简单易懂,搬运过来记录学习,并分享给大家
vue.extend 函数可以生成一个 组件构造器 可以用这个函数构造出一个 vue组件实例可以用 document.body.appendChild() 动态的把组件加到 body里面去vue.prototype.$toast = showToast 可以在全局注册组件显示动画比较简单,隐藏动画必须要在隐藏之前预留足够的动画执行时间
原文链接:感谢作者,遂附原文链接
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
