今天我们来自己动手用实现一个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插件的更多相关文章

  1. Android | 教你如何用华为HMS MLKit 图像分割 SDK开发一个证件照DIY小程序

    Android | 教你如何用华为HMS MLKit 图像分割 SDK开发一个证件照DIY小程序 引子   上期给大家介绍了如何使用如何用华为HMS MLKit SDK 三十分钟在安卓上开发一个微笑抓 ...

  2. 教你如何用PS制作多款按钮UI设计教程

    教你如何用PS制作多款按钮UI设计教程 本文教大家制作按钮的方法 LV. ★ 初入设计,学做按钮.只会套个底色,加个阴影,字体纯白,小聪明的弄个圆角. LV. ★★(描边.字体.内阴影) 看了很多案例 ...

  3. 手把手教你用Vue2+webpack+node开发一个H5 app

    手把手教你用Vue2+webpack+node开发一个H5 app ​前一篇vue2 + webpack + node 开发一个小demo说到了用vue的一些基本用法,这一篇就讲一个复杂一点的更完整的 ...

  4. 一篇文章教你如何用R进行数据挖掘

    一篇文章教你如何用R进行数据挖掘 引言 R是一种广泛用于数据分析和统计计算的强大语言,于上世纪90年代开始发展起来.得益于全世界众多 爱好者的无尽努力,大家继而开发出了一种基于R但优于R基本文本编辑器 ...

  5. 零元学Expression Design 4 - Chapter 5 教你如何用自制笔刷在5分钟内做出设计感效果

    原文:零元学Expression Design 4 - Chapter 5 教你如何用自制笔刷在5分钟内做出设计感效果 本章将教你如何运用笔刷与简单线条,只要5分钟,就能做出设计感效果 ? 本章将教你 ...

  6. 教你如何创建vue环境

    教你如何创建vue的环境 wdnmd我操作了一万年,终于成功创建了vue的环境,现在就来讲一下,到底应该怎么操作才能成功创建vue的 第一步 : 我们应该做的不是别的,而是去官方网站下载文件 node ...

  7. 如何用一月6RMB搭建一个国外服务器

    转载自我的博客:https://blog.ljyngup.com 前言 本文将教你如何用一月6RMB的价格搭建一个属于个人的外国服务器.并且一月500G流量,延迟低于500ms. 开始 导航:Virm ...

  8. Android | 教你如何用代码一键实现银行卡绑定

    前言   小编前面几期文章分别给大家介绍了用代码实现微笑抓拍.证件照DIY.拍照翻译的功能开发(链接见文章末尾),本次小编给大家带来的是用代码一键实现银行卡识别与绑定功能. 银行卡识别的应用场景    ...

  9. 如何用 React Native 创建一个iOS APP?(三)

    前两部分,<如何用 React Native 创建一个iOS APP?>,<如何用 React Native 创建一个iOS APP (二)?>中,我们分别讲了用 React ...

随机推荐

  1. C++ vector对象是如何增长的

    为了支持快速随机访问,vector将元素连续存储---每个元素紧挨着前一个元素存储. 如果没有空间容纳新元素: 容器必须分配新的内存空间来保存已有元素和新元素,将已有元素从旧位置移动到新空间中,然后添 ...

  2. 【WPF学习】第十七章 键盘输入

    当用户按下键盘上的一个键时,就会发生一系列事件.下表根据他们的发生顺序列出了这些事件: 表 所有元素的键盘事件(按顺序) 键盘处理永远不会像上面看到的这么简单.一些控件可能会挂起这些事件中的某些事件, ...

  3. Java中SMB的相关应用

    目录 SMB 服务操作 Ⅰ SMB简介 Ⅱ SMB配置 2.1 Windows SMB Ⅲ 添加SMB依赖 Ⅳ 路径格式 Ⅴ 操作共享 Ⅵ 登录验证 SMB 服务操作 Ⅰ SMB简介 ​ SMB(全称 ...

  4. 正斜杠(" / ")和反斜杠(" \ ")的区别

    反斜杠“\”是电脑出现了之后为了表示程序设计里的特殊含义才发明的专用标点.所以除了程序设计领域外,任何地方都不应该使用反斜杠. 如何区分正反斜杠 英语:"/" 英文是forward ...

  5. Nginx进阶

    常见的web架构 LAMP - Linux +Apache +MySQL + PHP LNMP - Linux +Nginx + Mysql + PHP RHEL开源  Linux系统  RHEL C ...

  6. CUDA学习(一)之使用GPU输出HelloWorld

    最近在学习CUDA,编程入门第一步便是“HelloWorld”,主要代码如下: #include "cuda_runtime.h" #include "device_la ...

  7. HTTPS 详解一:附带最精美详尽的 HTTPS 原理图

    HTTPS 详解一:附带最精美详尽的 HTTPS 原理图 HTTPS详解二:SSL / TLS 工作原理和详细握手过程 前言 作为一个有追求的程序员,了解行业发展趋势和扩充自己的计算机知识储备都是很有 ...

  8. ATL的GUI程序设计(前言)

    前言 也许,你是一个顽固的SDK簇拥者: 也许,你对MFC抱着无比排斥的态度,甚至像我一样对它几乎一无所知: 也许,你符合上面两条,而且正在寻求着一种出路: 也许,你找到了一条出路--WTL,但是仍然 ...

  9. mplayer命令行模式下的使用方法【转】

    mplayer命令行模式下的使用方法http://hi.baidu.com/lovehack2006/blog/item/162ef9778214111eb051b9d4.htmlMPlayerMPl ...

  10. Codeforces_731_C

    http://codeforces.com/problemset/problem/731/C 并查集,然后找每个集合里颜色的最大数量,求集合中元素数量-这个最大数量,最后总数相加即答案. #inclu ...