用Vue.extend构建消息提示组件的方法实例


Posted in Javascript onAugust 08, 2017

前提

前段时间自己做的vue练手项目,需要一个通用的消息提示组件,但是消息提示这种组件我更想用方法来调用,而不是在各个页面上都添加个组件(那样感觉很麻烦,重度懒癌患者),于是就上网差查了查,并研究了ElementUI的message源码。自己弄出来一个简陋的消息提示组件

Vue.extend是什么

用Vue.extend构建消息提示组件的方法实例

按照官方文档说法,他是一个类构造器,用来创建一个子类vue并返回构造函数,而Vue.component它的任务是将给定的构造函数与字符串ID相关联,以便Vue.js可以在模板中接收它。
了解了这点之后我们开始做我们的消息提示组件吧。

消息提示组件

首先我们先创建我们的提示组件的模板

<template>
  <transition name="message-fade">
    <div class="message" v-show="show">
    <span class="icon"><icon name="info"></icon></span>
      <p>{{message}}</p>
    </div>
  </transition>
</template>

<script>
  export default {
    name: 'v-message',
    mounted(){
      this.StartTime();
    },
    data(){
      return {
        message: '123',
        show: false,
        timer: null
      }
    },
    methods:{
      StartTime(){
        this.show = true;
        if(this.timer){
          clearTimeOut(this.timer)
        }else{
          this.timer = setTimeout(()=>{
            this.show = false
          }, 3000);
        }
      }
    }
  }
</script>

之后我们需要用将message.vue传到Vue.extend()里

import Vue from 'vue';
let MessageBox = Vue.extend(require('./message.vue'));
let instance;
var message = function(options){
  if(typeof options === 'string'){
    options = {
      message: options
    }
  }
  //生成组件
  instance = new MessageBox({
    data: options
  })
  //组件需要挂载在dom元素上
  instance.vm = instance.$mount();
  //根据不同的类型,设置不同消息的背景颜色
  if(options.type){
    instance.vm.$el.children[0].className += ` icon__${options.type}`;
  }
  document.body.appendChild(instance.vm.$el);
  return instance.vm;
}

const type = ['success', 'info', 'warning', 'error'];
type.forEach((type)=>{
  message[type] = options =>{
    if(typeof options === 'string'){
      options = {
        message: options
      }
    }
    options.type = type;
    return message(options);
  }
})

export default message;

之后用挂在全局方法上,之后用this.$message()方法调用

vue.prototype.$message = message;

最后的效果图

用Vue.extend构建消息提示组件的方法实例

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery ajax提交表单数据的两种实现方法
Apr 29 Javascript
仅IE6/7/8中innerHTML返回值忽略英文空格的问题
Apr 07 Javascript
js中判断Object、Array、Function等引用类型对象是否相等
Aug 29 Javascript
JS保留两位小数 四舍五入函数的小例子
Nov 20 Javascript
jquery ui dialog替代confirm实例分析
Jan 25 Javascript
JS 终止执行的实现方法
Nov 24 Javascript
微信小程序 列表的上拉加载和下拉刷新的实现
Apr 01 Javascript
vue-router 权限控制的示例代码
Sep 21 Javascript
在iFrame子页面里实现模态框的方法
Aug 17 Javascript
JS/HTML5游戏常用算法之追踪算法实例详解
Dec 12 Javascript
17道题让你彻底理解JS中的类型转换
Aug 08 Javascript
使用vue制作滑动标签
Sep 21 Javascript
基于Vue实现页面切换左右滑动效果
Jun 29 #Javascript
VUE实现表单元素双向绑定(总结)
Aug 08 #Javascript
ES6模块化的import和export用法方法总结
Aug 08 #Javascript
Vue项目中quill-editor带样式编辑器的使用方法
Aug 08 #Javascript
webpack 2.x配置reactjs基本开发环境详解
Aug 08 #Javascript
vue-quill-editor实现图片上传功能
Aug 08 #Javascript
vue.js评论发布信息可插入QQ表情功能
Aug 08 #Javascript
You might like
PHP学习笔记 (1) 环境配置与代码调试
2011/06/19 PHP
浅谈PHP的排列组合(如输入a,b,c 输出他们的全部组合)
2017/03/14 PHP
基于jquery的一个图片hover的插件
2010/04/24 Javascript
jQuery在iframe中无法弹出对话框的解决方法
2014/01/12 Javascript
jQuery中nextUntil()方法用法实例
2015/01/07 Javascript
NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法
2016/07/26 NodeJs
JavaScript每天必学之基础知识
2016/09/17 Javascript
vue实现简单实时汇率计算功能
2017/01/15 Javascript
JS实现控制图片显示大小的方法【图片等比例缩放功能】
2017/02/18 Javascript
JavaScript错误处理和堆栈追踪详解
2017/04/18 Javascript
详谈表单格式化插件jquery.serializeJSON
2017/06/23 jQuery
Node.js如何使用Diffie-Hellman密钥交换算法详解
2017/09/05 Javascript
vue2.0开发入门笔记之.vue文件的生成和使用
2017/09/19 Javascript
vue 项目中使用Loading组件的示例代码
2018/08/31 Javascript
js实现盒子拖拽动画效果
2020/08/09 Javascript
[06:33]3.19 DOTA2发布会 海涛、冷冷、2009见证希望
2014/03/21 DOTA
django 按时间范围查询数据库实例代码
2018/02/11 Python
python flask中静态文件的管理方法
2018/03/20 Python
使用Python的toolz库开始函数式编程的方法
2018/11/15 Python
pymysql模块的使用(增删改查)详解
2019/09/09 Python
如何基于python测量代码运行时间
2019/12/25 Python
python scrapy重复执行实现代码详解
2019/12/28 Python
部署Django到阿里云服务器教程示例
2020/06/03 Python
CSS的pointer-events属性详细介绍(作用和注意事项)
2014/04/23 HTML / CSS
皇马官方商城:Real Madrid Store
2016/09/02 全球购物
Glamest意大利:女性在线奢侈品零售店
2019/04/28 全球购物
纬创Java面试题笔试题
2014/10/02 面试题
银行学习十八大感想
2014/01/11 职场文书
报关专员求职信范文
2014/02/22 职场文书
食品工程专业求职信
2014/06/15 职场文书
精神文明建设标语
2014/06/16 职场文书
单位单身证明样本
2014/10/11 职场文书
2014年煤矿安全工作总结
2014/12/04 职场文书
杭白菊导游词
2015/02/10 职场文书
2015年师德表现自我评价
2015/03/05 职场文书
2015年护理工作总结范文
2015/04/03 职场文书