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

发布时间 - 2026-01-11 02:41:53    点击率:

前提

前段时间自己做的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;

最后的效果图

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


# Vue.extend  # 消息提示  # vue  # 消息提示组件  # Vue组件教程之Toast(Vue.extend 方式)详解  # 手把手教你写一个vue全局注册的Toast的实现  # vue使用Vue.extend创建全局toast组件实例  # 子类  # 相关联  # 挂在  # 上都  # 我更  # 想用  # 方法来  # 他是一个  # 创建一个  # 前段时间  # 需要用  # 弄出  # 大家多多  # 很麻烦  # 而不是  # 文档  # 在各个  # pre  # lt  # brush 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何用VPS主机快速搭建个人网站?  如何快速搭建虚拟主机网站?新手必看指南  如何有效防御Web建站篡改攻击?  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  *服务器网站为何频现安全漏洞?  公司门户网站制作流程,华为官网怎么做?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  如何用搬瓦工VPS快速搭建个人网站?  如何在宝塔面板中修改默认建站目录?  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程  智能起名网站制作软件有哪些,制作logo的软件?  黑客如何利用漏洞与弱口令入侵网站服务器?  如何用景安虚拟主机手机版绑定域名建站?  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  ,怎么在广州志愿者网站注册?  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  北京企业网站设计制作公司,北京铁路集团官方网站?  如何正确选择百度移动适配建站域名?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  如何自定义建站之星网站的导航菜单样式?  如何快速搭建高效服务器建站系统?  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  如何在阿里云购买域名并搭建网站?  如何在Windows虚拟主机上快速搭建网站?  Laravel如何处理表单验证?(Requests代码示例)  创业网站制作流程,创业网站可靠吗?  微信小程序 input输入框控件详解及实例(多种示例)  ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】  EditPlus中的正则表达式实战(6)  Laravel安装步骤详细教程_Laravel环境搭建指南  Laravel如何实现API版本控制_Laravel版本化API设计方案  Windows Hello人脸识别突然无法使用  成都网站制作公司哪家好,四川省职工服务网是做什么用?  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  独立制作一个网站多少钱,建立网站需要花多少钱?  使用spring连接及操作mongodb3.0实例  HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  高性价比服务器租赁——企业级配置与24小时运维服务  专业商城网站制作公司有哪些,pi商城官网是哪个?  如何快速启动建站代理加盟业务?  QQ浏览器网页版登录入口 个人中心在线进入  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  Laravel怎么在Controller之外的地方验证数据