用Vue.extend构建消息提示组件

发布时间:2019-05-15 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了用Vue.extend构建消息提示组件脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

前提

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

Vue.extend是什么

clipboard.png
按照官方文档说法,他是一个类构造器,用来创建一个子类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;

最后的效果图

clipboard.png

脚本宝典总结

以上是脚本宝典为你收集整理的用Vue.extend构建消息提示组件全部内容,希望文章能够帮你解决用Vue.extend构建消息提示组件所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。