用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 相关文章推荐
JS实现可直接显示网页代码运行效果的HTML代码预览功能实例
Aug 06 Javascript
使用bootstrap3开发响应式网站
May 12 Javascript
修改Jquery Dialog 位置的实现方法
Aug 26 Javascript
几句话带你理解JS中的this、闭包、原型链
Sep 26 Javascript
JS判断鼠标进入容器的方向与window.open新窗口被拦截的问题
Dec 23 Javascript
用 js 的 selection range 操作选择区域内容和图片
Apr 18 Javascript
详解vue.js 开发环境搭建最简单攻略
Jun 12 Javascript
基于vue-ssr服务端渲染入门详解
Jan 08 Javascript
详解Angular Forms中自定义ngModel绑定值的方式
Dec 10 Javascript
微信小程序基于高德地图查找位置并显示文字
Oct 30 Javascript
Vue实现Header渐隐渐现效果的实例代码
Nov 05 Javascript
Canvas跟随鼠标炫彩小球的实现
Apr 11 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
mysql 搜索之简单应用
2007/04/27 PHP
thinkphp区间查询、统计查询与SQL直接查询实例分析
2014/11/24 PHP
php同时使用session和cookie来保存用户登录信息的实现代码
2016/05/13 PHP
php基于curl实现的股票信息查询类实例
2016/11/11 PHP
gearman中worker常驻后台,导致MySQL server has gone away的解决方法
2020/02/27 PHP
CSDN轮换广告图片轮换效果
2007/03/27 Javascript
JS注册/移除事件处理程序(ExtJS应用程序设计实战)
2013/05/07 Javascript
原生JS实现表单checkbook获取已选择的值
2013/07/21 Javascript
JS,Jquery获取select,dropdownlist,checkbox下拉列表框的值(示例代码)
2014/01/11 Javascript
js中创建对象的几种方式示例介绍
2014/01/26 Javascript
深入理解JavaScript系列(29):设计模式之装饰者模式详解
2015/03/03 Javascript
js实现简单鼠标跟随效果的方法
2015/04/10 Javascript
JavaScript之AOP编程实例
2015/07/17 Javascript
深入理解jquery中extend的实现
2016/12/22 Javascript
Angular4学习笔记之准备和环境搭建项目
2017/08/01 Javascript
简单谈谈js的数据类型
2017/09/25 Javascript
vue2.0 路由不显示router-view的解决方法
2018/03/06 Javascript
React路由管理之React Router总结
2018/05/10 Javascript
解决layui 表单元素radio不显示渲染的问题
2019/09/04 Javascript
Vue数字输入框组件的使用方法
2019/10/19 Javascript
VUE前端从后台请求过来的数据进行转换数据结构操作
2020/11/11 Javascript
使用Python压缩和解压缩zip文件的教程
2015/05/06 Python
pandas的连接函数concat()函数的具体使用方法
2019/07/09 Python
Python实现企业微信机器人每天定时发消息实例
2020/02/25 Python
Python Tkinter Entry和Text的添加与使用详解
2020/03/04 Python
解决Django提交表单报错:CSRF token missing or incorrect的问题
2020/03/13 Python
Windows 平台做 Python 开发的最佳组合(推荐)
2020/07/27 Python
Pytest测试框架基本使用方法详解
2020/11/25 Python
如何在Canvas上的图形/图像绑定事件监听的实现
2020/09/16 HTML / CSS
园林资料员岗位职责
2013/12/30 职场文书
银行员工职业规划范文
2014/01/21 职场文书
人力资源部经理岗位职责规定
2014/02/23 职场文书
模具专业毕业推荐信
2014/03/08 职场文书
赞美老师的演讲稿
2014/05/22 职场文书
初三英语教学反思
2016/02/15 职场文书
如何将JavaScript将数组转为树形结构
2021/06/02 Javascript