用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 相关文章推荐
javascript使用avalon绑定实现checkbox全选
May 06 Javascript
window.close(); 关闭浏览器窗口js代码的总结介绍
Jul 14 Javascript
jQuery+HTML5+CSS3制作支持响应式布局时间轴插件
Aug 10 Javascript
JS+Ajax实现百度智能搜索框
Aug 04 Javascript
express如何使用session与cookie的方法
Jan 30 Javascript
Vue组件库发布到npm详解
Feb 17 Javascript
解决vuejs项目里css引用背景图片不能显示的问题
Sep 13 Javascript
在js代码拼接dom对象到页面上的模板总结
Oct 21 Javascript
vue框架下部署上线后刷新报404问题的解决方案(推荐)
Apr 03 Javascript
前端js中的事件循环eventloop机制详解
May 15 Javascript
element-ui tooltip修改背景颜色和箭头颜色的实现
Dec 16 Javascript
JS实现旋转木马轮播图
Jan 01 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中数据的批量导入(csv文件)
2006/10/09 PHP
php file_put_contents()功能函数(集成了fopen、fwrite、fclose)
2011/05/24 PHP
PHP中使用crypt()实现用户身份验证的代码
2012/09/05 PHP
php命令行使用方法和命令行参数说明
2014/04/08 PHP
PHP 匿名函数与注意事项详细介绍
2016/11/26 PHP
Laravel中正确地返回HTTP状态码方法示例
2019/09/10 PHP
一个简单的JavaScript 日期计算算法
2009/09/11 Javascript
JavaScript CSS修改学习第三章 修改样式表
2010/02/19 Javascript
PHP+jQuery+Ajax+Mysql如何实现发表心情功能
2015/08/06 Javascript
js 判断所选时间(或者当前时间)是否在某一时间段的实现代码
2015/09/05 Javascript
jQuery无刷新分页完整实例代码
2015/10/27 Javascript
jQuery on()方法绑定动态元素的点击事件实例代码浅析
2016/06/16 Javascript
JQuery中解决重复动画的方法
2016/10/17 Javascript
基于JS实现9种不同的面包屑和分布式多步骤导航效果
2017/02/21 Javascript
详解NodeJS框架express的路径映射(路由)功能及控制
2017/03/24 NodeJs
jQuery查找dom的几种方法效率详解
2017/05/17 jQuery
微信小程序实现获取用户信息并存入数据库操作示例
2019/05/07 Javascript
Vue数据驱动表单渲染,轻松搞定form表单
2019/07/19 Javascript
JQuery复选框全选效果如何实现
2020/05/08 jQuery
Python写的服务监控程序实例
2015/01/31 Python
Python爬虫爬验证码实现功能详解
2016/04/14 Python
Python实现简单的四则运算计算器
2016/11/02 Python
Python入门_条件控制(详解)
2017/05/16 Python
Python开发的HTTP库requests详解
2017/08/29 Python
代码分析Python地图坐标转换
2018/02/08 Python
Python面向对象程序设计类的封装与继承用法示例
2019/04/12 Python
python 求某条线上特定x值或y值的点坐标方法
2019/07/09 Python
python中for循环把字符串或者字典添加到列表的方法
2019/07/20 Python
Python 实现try重新执行
2019/12/21 Python
python实现提取str字符串/json中多级目录下的某个值
2020/02/27 Python
解决Django提交表单报错:CSRF token missing or incorrect的问题
2020/03/13 Python
京东奢侈品:全球奢侈品牌
2018/03/17 全球购物
学生会干部自荐信
2014/02/04 职场文书
2015年会计工作总结范文
2015/05/26 职场文书
《天净沙·秋思》教学反思三篇
2019/11/02 职场文书
MySQL分区表实现按月份归类
2021/11/01 MySQL