使用Vue.extend( ) 模仿 elementui 创建一个类似 message 消息提示框

提示:记录工作中遇到的需求及解决办法

文章目录

  • 前言
  • 一、目录结构
  • 二、代码
      • [1. 创建 m-Toast.vue 文件](#1. 创建 m-Toast.vue 文件)
      • [2. 创建 global.js 文件](#2. 创建 global.js 文件)
      • [3. 在 main.js 文件中导入 global.js 文件](#3. 在 main.js 文件中导入 global.js 文件)
      • [4. 在 App.vue 文件中使用 全局方法创建的 组件](#4. 在 App.vue 文件中使用 全局方法创建的 组件)

前言

在此之前一直不明白Vue.extend( )干什么用的,如何使用,看了一些视频,再结合vue文档,浅浅的理解了一些,以及一些简单的应用,如有不对请指出。

我将使用脚手架生成一个vue2项目来解释。


提示:以下是本篇文章正文内容,下面案例可供参考

一、目录结构

二、代码

1. 创建 m-Toast.vue 文件

js 复制代码
<template>
	<div class="message">
		<div class="text">{{ text }}</div>
	</div>
</template> 
<script>
export default {
	name: 'm-Toast',
	props: {
		text: {
			type: String,
			default: ''
		},
	},
	mounted () {
		this.timer = setTimeout(() => {
			this.$destroy()
			clearTimeout(this.timer);
		}, 2000)
	},
	destroyed () {
		clearTimeout(this.timer);
		document.body.removeChild(this.$el)
	},
	methods: {

	},
}
</script>
<style scoped>
.message {
	min-width: 380px;
	background-color: #f0f9eb;
	color: #67c23a;
	position: fixed;
	padding: 15px 15px 15px 20px;
	top: 20px;
	left: 50%;
	z-index: 2022;
	font-size: 14px;
	transform: translate(-50%, 0);
}

.text {
	overflow: hidden;
	align-items: center;
}
</style>

2. 创建 global.js 文件

js 复制代码
import Vue from "vue";
import Toast from "./components/m-Toast.vue";

/** 创建 Toast对应的Vue子类(构造器)
 * 结合vue文档 和 视频,
 * extends 的参数可以通过导入一个写好的组件
 * 或者 是函数 ,例如: 
 * {
 *	template: '<div class="message">
 *								<div class="text">{{ text }}</div>
 *							</div>',
 *	data: function () {
 *		return {
 *			text: '测试',
 *		}
 *	}
 * }
 * 下面我选择通过导入组件的方法,因为方便使用样式,结构更明了
 */
let ToastSubclass = Vue.extend(Toast)

// 全局挂载到原型上方便调用
Vue.prototype.$toast = function (text) {
	// 创建实例
	let ToastConstructor = new ToastSubclass({
		// 就是在调用组件的时候,给组件传递属性值
		propsData: {
			text
		}
	});

	/** 挂载(渲染组件)
	 * 使用 $mount() 但不传挂载点,返回一个完整的 Vue 组件实例
	 */
	ToastConstructor.$mount()

	// 把渲染后的真实DOM插入到BODY中即可
	document.body.appendChild(ToastConstructor.$el)
}

3. 在 main.js 文件中导入 global.js 文件

js 复制代码
import Vue from 'vue'
import App from './App.vue'
// 导入 global.js 文件
import './global.js'

Vue.config.productionTip = false

new Vue({
	render: h => h(App),
}).$mount('#app')

4. 在 App.vue 文件中使用 全局方法创建的 组件

js 复制代码
<template>
	<div id="app">
		<button @click="config">按钮</button>
	</div>
</template>

<script>

export default {
	name: 'App',
	data () {
		return {
			count: 0
		}
	},
	mounted () {

	},
	methods: {
		config () {
			this.$toast(`测试${this.count++}`)
		}
	}
}
</script>

<style></style>
相关推荐
低保和光头哪个先来1 小时前
场景6:对浏览器内核的理解
开发语言·前端·javascript·vue.js·前端框架
+VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vueOA工程项目管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
ji_shuke2 小时前
canvas绘制拖拽箭头
开发语言·javascript·ecmascript
2501_946244782 小时前
Flutter & OpenHarmony OA系统设置页面组件开发指南
开发语言·javascript·flutter
cz追天之路2 小时前
华为机考 ------ 识别有效的IP地址和掩码并进行分类统计
javascript·华为·typescript·node.js·ecmascript·less·css3
进击的野人2 小时前
Vue Router 深度解析:从基础概念到高级应用实践
前端·vue.js·前端框架
l1t3 小时前
DeepSeek总结的算法 X 与舞蹈链文章
前端·javascript·算法
JIngJaneIL3 小时前
基于java+ vue学生成绩管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端
千寻girling3 小时前
面试官 : “ 说一下 localhost 和127.0.0.1 的区别 ? ”
前端·javascript·面试
老华带你飞3 小时前
智能菜谱推荐|基于java + vue智能菜谱推荐系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot