教你如何用Vue自己实现一个message插件
今天我们来自己动手用实现一个message插件:
Vue.js 的插件应该暴露一个 install
方法。这个方法的第一个参数是 Vue
构造器,第二个参数是一个可选的选项对象:
//message.vue
<template>
<transition name="msg-fade">
<div class="message" :class="type" v-show="visible">
<span class="icon"></span>
<p class="content">{{content}}</p>
<span class="delete-icon" @click="onCancle">x</span>
</div>
</transition>
</template> <script>
const Msg = {
name:'message',
data(){
return {
visible:false,
type:'',
content:''
}
},
install(Vue){
Vue.prototype.$msg = (config)=>{ //通过原型注册一个方法
const MessageConstructor = Vue.extend(Msg); //生成一个Vue子类,子类就是这个组件
const instance = new MessageConstructor({data:config}); //生成该子类的实例
instance.vm = instance.$mount(); //将该实例手动挂载
document.body.appendChild(instance.vm.$el); //将实例挂载到body上
instance.vm.visible = true;
}
}
},
watch:{
visible(v){
if(v){
setTimeout(()=>{
this.onClose()
},3000)
}
}
},
methods:{
onClose(){
this.visible = false
this.$el.parentNode.removeChild(this.$el)
},
show(){
this.visible = true
},
onCancle(){
if(this.cancelBtn){
this.cancelBtn.apply(this.content)
};
this.onClose();
}
}, } export default Msg
</script> <style scoped lang='less'>
.message {
position: fixed;
left: 50%;
top: 50%;
transform: translate3d(-50%,-50%,0);
background: rgba(0,0,0, 0.6);
z-index: 1000;
min-width: 288px;
height: 32px;
box-sizing: border-box;
.icon{
display: inline-block;
width: 12px;
height: 12px;
margin-left: 16px;
background: url(../assets/default.svg) no-repeat;
background-size: 12px 12px;
vertical-align: middle;
}
&.success {
background: #EBF8F2;
border: 1px solid #A7E1C4;
border-radius: 4px;
.icon{
background: url(../assets/success.svg)no-repeat;
background-size: 12px 12px;
}
}
&.warn {
background: #FFFAEB;
border: 1px solid #FCCCA7;
border-radius: 4px;
.icon{
background: url(../assets/remind.svg)no-repeat;
background-size: 12px 12px;
}
}
&.error {
background: #FEF3EB;
border: 1px solid #FFE9A7;
border-radius: 4px;
.icon{
background: url(../assets/error.svg)no-repeat;
background-size: 12px 12px;
}
}
.content{
display: inline-block;
font-size: 12px;
color: rgba(0,0,0,0.65);
letter-spacing: 0;
line-height: 30px;
margin-left: 8px;
}
.delete-icon{
display: block;
width: 10px;
height: 10px;
position:absolute;
top:9px;
right:12px;
font-size:18px;
line-height: 10px;
cursor: pointer;
color: #000;
opacity: .43;
}
} .msg-fade-enter-active {
animation: alert-fade-in .3s;
} .msg-fade-leave-active {
animation: alert-fade-out .3s;
} @keyframes alert-fade-in {
0% {
opacity: 0;
}
100% {
opacity: 1;
}
} @keyframes alert-fade-out {
0% {
opacity: 1;
}
100% {
opacity: 0;
}
}
</style> //main.js
import msg from './components/Message';
Vue.use(msg); //使用:
this.$msg({
type:'error',
content:'这是一条自定义消息'
})
效果如图![]()
教你如何用Vue自己实现一个message插件的更多相关文章
- Android | 教你如何用华为HMS MLKit 图像分割 SDK开发一个证件照DIY小程序
Android | 教你如何用华为HMS MLKit 图像分割 SDK开发一个证件照DIY小程序 引子 上期给大家介绍了如何使用如何用华为HMS MLKit SDK 三十分钟在安卓上开发一个微笑抓 ...
- 教你如何用PS制作多款按钮UI设计教程
教你如何用PS制作多款按钮UI设计教程 本文教大家制作按钮的方法 LV. ★ 初入设计,学做按钮.只会套个底色,加个阴影,字体纯白,小聪明的弄个圆角. LV. ★★(描边.字体.内阴影) 看了很多案例 ...
- 手把手教你用Vue2+webpack+node开发一个H5 app
手把手教你用Vue2+webpack+node开发一个H5 app 前一篇vue2 + webpack + node 开发一个小demo说到了用vue的一些基本用法,这一篇就讲一个复杂一点的更完整的 ...
- 一篇文章教你如何用R进行数据挖掘
一篇文章教你如何用R进行数据挖掘 引言 R是一种广泛用于数据分析和统计计算的强大语言,于上世纪90年代开始发展起来.得益于全世界众多 爱好者的无尽努力,大家继而开发出了一种基于R但优于R基本文本编辑器 ...
- 零元学Expression Design 4 - Chapter 5 教你如何用自制笔刷在5分钟内做出设计感效果
原文:零元学Expression Design 4 - Chapter 5 教你如何用自制笔刷在5分钟内做出设计感效果 本章将教你如何运用笔刷与简单线条,只要5分钟,就能做出设计感效果 ? 本章将教你 ...
- 教你如何创建vue环境
教你如何创建vue的环境 wdnmd我操作了一万年,终于成功创建了vue的环境,现在就来讲一下,到底应该怎么操作才能成功创建vue的 第一步 : 我们应该做的不是别的,而是去官方网站下载文件 node ...
- 如何用一月6RMB搭建一个国外服务器
转载自我的博客:https://blog.ljyngup.com 前言 本文将教你如何用一月6RMB的价格搭建一个属于个人的外国服务器.并且一月500G流量,延迟低于500ms. 开始 导航:Virm ...
- Android | 教你如何用代码一键实现银行卡绑定
前言 小编前面几期文章分别给大家介绍了用代码实现微笑抓拍.证件照DIY.拍照翻译的功能开发(链接见文章末尾),本次小编给大家带来的是用代码一键实现银行卡识别与绑定功能. 银行卡识别的应用场景 ...
- 如何用 React Native 创建一个iOS APP?(三)
前两部分,<如何用 React Native 创建一个iOS APP?>,<如何用 React Native 创建一个iOS APP (二)?>中,我们分别讲了用 React ...
随机推荐
- 使用RobotFramework的DataBaseLibrary(Java实现)
RobotFramework能用Python和Jython两条腿走路.但有的时候你得选一条.今天就碰上个问题,为了整合其它模块必须用Java实现的DataBaseLibrary 其实实它很简单,记录步 ...
- Java 中的等待唤醒机制透彻讲解
线程的状态 首先了解一下什么是线程的状态,线程状态就是当线程被创建(new),并且启动(start)后,它不是一启动就进入了执行状态(run),也不是一直都处于执行状态. 这里说一下Java 的Thr ...
- 国产CPU 申威1621 异数OS基础组件理论性能测试报告
国产CPU 申威1621 异数OS基础组件理论性能测试报告 文章目录 国产CPU 申威1621 异数OS基础组件理论性能测试报告 前言 测试平台 测试项目 SW1621 异数OS 容器虚拟交换机模拟性 ...
- python打包成可执行文件
1 最开始我直接把在Windows上打包的run.exe文件上传到Linux以为可以直接用了.但是./run后报错.百度后知道,Windows上的程序不能在Linux上运行 Linux下文件是否可执行 ...
- airtest启用本地python环境的方法
实现目标,air如果想引用第三方python库,则需要在本地python欢迎执行运行 1.打开设置,红色箭头处,选择本地python路径 2.安装air的两个核心库airtest和pocoui 安装方 ...
- Postwoman-接口测试工具
地址是:https://postwoman.io/ ,不过只能使用它们自己提供的测试接口,如果你调试自己的API接口的话,你需要自己部署一套代码. 自己搭建一套Postwomen环境的话,只需要安装了 ...
- Python PID
import time class PID: """PID Controller """ def __init__(self, P=0.2, ...
- http--->http缓存机制系统梳理
http缓存 HTTP请求的过程 从在浏览器地址栏敲入域名-DNS解析-实际IP-(中间可能多个代理服务器分发)- 源服务器,请求抵达源服务器后,在服务器上找到请求的资源,再通过代理服务器一层层的返回 ...
- nginx之文件配置
nginx配置规则 nginx由受配置文件中指定的指令控制的模块组成 伪指令分为简单伪指令和块伪指令 简单的指令由名称和参数组成,这些名称和参数之间用空格分隔,并以分号(;)结尾 块指令的结构 与 简 ...
- Linux下安装nvidia显卡驱动
部署环境 操作系统:Centos 7.4 在线源:Centos 7.4镜像源 安装操作 1.安装系统插件 [root@localhost ~]# yum -y install gcc kernel-d ...