最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-27 22:33:00
文档

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

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

前提

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

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;

最后的效果图

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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

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

最新推荐

猜你喜欢

热门推荐

专题
Top