Vue 封装全局提示组件
时间:2020-05-30
本文章向大家介绍Vue 封装全局提示组件,主要包括Vue 封装全局提示组件使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
新建一个Toast组件
1 <template> 2 <transition name="fade"> 3 <div v-show="visible">{{message}}</div> 4 </transition> 5 </template> 6 7 <script> 8 export default { 9 data () { 10 return { 11 visible: false, 12 message: '' 13 } 14 } 15 } 16 </script> 17 18 <style scoped> 19 div { 20 padding: 5px 20px; 21 color: #fff; 22 background-color: #3596ff; 23 text-align: center; 24 position: fixed; 25 top: 30%; 26 left: 50%; 27 transform: translate(-50%, -50%); 28 } 29 /* vue动画过渡效果设置 */ 30 .fade-enter-active, 31 .fade-leave-active { 32 transition: opacity .5s; 33 } 34 .fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ { 35 opacity: 0; 36 } 37 </style>
在main.js里面配置如下
import Toasts from './components/Toast' const Toast = { install: function (Vue) { // 创建一个Vue的“子类”组件 const ToastConstructor = Vue.extend(Toasts) // 创建一个该子类的实例,并挂载到一个元素上 const instance = new ToastConstructor() // 将这个实例挂载到动态创建的元素上,并将元素添加到全局结构中 instance.$mount(document.createElement('div')) document.body.appendChild(instance.$el) // 在Vue的原型链上注册方法,控制组件 Vue.prototype.$toast = (msg, duration = 1500) => { instance.message = msg instance.visible = true setTimeout(() => { instance.visible = false }, duration) } } } Vue.use(Toast)
在组件内调用
<template> <div> <button @click="onClick">1111</button> </div> </template> <script> export default { name: "App", components: { }, data() { return { }; }, methods:{ onClick(){ // 使用全局 toast this.$toast('提示内容') } } }; </script> <style lang="less"> </style>
效果如下
原文地址:https://www.cnblogs.com/z-j-c/p/12994076.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 仿抖音短视频APP源码,实现简单的换头像并保存
- php实现JWT(json web token)鉴权实例详解
- laravel实现上传图片,并且制作缩略图,按照日期存放的代码
- 在Laravel中使用MongoDB的方法示例
- 基于thinkphp6.0的success、error实现方法
- Yii框架模拟组件调用注入示例
- 解决laravel 表单提交-POST 异常的问题
- laravel5.0在linux下解决.htaccess无效和去除index.php的问题
- laravel返回统一格式错误码问题
- 使用 PHP Masked Package 屏蔽敏感数据的实现方法
- PHP简单实现图片格式转换(jpg转png,gif转png等)
- 在thinkphp5.0路径中实现去除index.php的方式
- Laravel5.5 手动分页和自定义分页样式的简单实现
- laravel自定义分页的实现案例offset()和limit()
- Laravel6.0.4中将添加计划任务事件的方法步骤