当前位置: 首页 > news >正文

Vue3中的混入(mixins)

在这里插入图片描述

本文主要介绍Vue3中的混入(mixins)。

目录

    • 一、在普通写法中使用混入:
    • 二、在setup写法中使用混入:

混入是Vue中一种用于在组件中共享可复用功能的特性。在Vue 3中,混入的使用方式有所改变。

一、在普通写法中使用混入:

下面是一个详细介绍Vue 3中混入的例子:

首先,可以定义一个混入对象,它包含了一些可复用的功能:

const myMixin = {data() {return {message: 'Hello from mixin!'}},mounted() {console.log('Mixin mounted');},methods: {sayHello() {console.log(this.message);}}
}

接下来,可以在组件中使用这个混入对象:

const App = {mixins: [myMixin],data() {return {name: 'John'}},mounted() {console.log('App mounted');},methods: {greet() {console.log('Hello, ' + this.name);this.sayHello();}}
}

在上面的例子中,我们在App组件中使用了myMixin混入对象。这意味着App组件将继承混入对象中的数据、方法和生命周期钩子函数。

当组件实例化后,将会触发钩子函数,先触发混入对象中的钩子函数,然后触发组件自身的钩子函数。所以,上面的例子中,当App组件实例化后,会先触发混入对象的mounted钩子函数,然后再触发App组件自身的mounted钩子函数。

此外,混入对象中的数据和方法会合并到组件自身的数据和方法中。所以,上面的例子中,App组件拥有一个名为message的数据属性,还拥有一个名为sayHello的方法。

总结一下,Vue 3中的混入是一种能够在组件中共享可复用功能的特性。通过将混入对象传入组件的mixins选项中,可以继承混入对象中的数据、方法和生命周期钩子函数。混入对象中的数据和方法会与组件自身的数据和方法合并。

二、在setup写法中使用混入:

使用<script setup lang="ts">语法,可以在Vue 3中使用混入。

下面是一个例子:

<template><div><p>{{ message }}</p><button @click="sayHello">Say Hello</button></div>
</template><script setup lang="ts">
import { ref } from 'vue';const message = ref('');const sayHello = () => {console.log('Hello from mixin!');
};const myMixin = {mounted() {console.log('Mixin mounted');}
};// 使用混入
export default {mixins: [myMixin],setup() {// 在组件中使用混入的数据和方法message.value = 'Hello World';return {message,sayHello};}
}
</script>

在上面的例子中,我们首先使用<script setup lang="ts">定义了组件的逻辑部分。在逻辑部分中,我们导入了Vue的ref函数,用于创建一个响应式数据。

然后,我们定义了一个名为message的响应式数据,使用ref函数将其初始化为空字符串。

接下来,我们定义了一个名为sayHello的方法,用于打印一条信息到控制台。

然后,我们定义了一个名为myMixin的混入对象,其中包含了一个mounted生命周期钩子函数。

最后,在组件的setup函数中,我们使用mixins选项将混入对象应用到当前组件。在setup函数中,我们可以像使用普通的Vue 3组件一样,使用混入对象的数据和方法。我们将message的值设置为Hello World,并将sayHello方法绑定到按钮的点击事件。

当组件实例化后,混入对象的mounted钩子函数将会触发,然后组件自身的mounted钩子函数将会触发。

通过在<script setup lang="ts">中定义混入对象,可以在Vue 3中使用混入。使用mixins选项将混入对象应用到组件,并在setup函数中使用混入的数据和方法。

在使用Vue 3的混入(mixins)功能时,有一些需要注意的地方:

  1. 冲突:如果混入(mixins)和组件本身的选项冲突,组件本身的选项将会优先生效。如果有冲突的选项,可以使用相同的名字创建组件本身的选项来覆盖混入(mixins)的选项。

  2. 生命周期钩子:Vue 3中的混入(mixins)中的生命周期钩子函数会在组件的生命周期之前调用。如果有多个混入(mixins),它们的生命周期钩子函数将按照混入(mixins)的声明顺序依次调用。

  3. 响应式属性:Vue 3中的混入(mixins)在组件内部使用的响应式属性需要在组件内部声明,否则它们将不会被响应式地追踪。

  4. 方法和计算属性:Vue 3中的混入(mixins)中的方法和计算属性会与组件本身的方法和计算属性合并。如果有冲突的方法或计算属性,组件本身的方法和计算属性将会覆盖混入(mixins)的方法和计算属性。

  5. 全局混入(mixins):Vue 3中已经移除了全局混入(mixins)的功能,不再推荐使用全局混入(mixins)。如果需要在多个组件中共享代码,可以考虑使用Composition API或自定义指令等其他方式。

在使用Vue 3的混入(mixins)时,需要注意组件选项冲突、生命周期钩子的调用顺序、响应式属性的声明和覆盖、方法和计算属性的合并,以及全局混入(mixins)的移除。

相关文章:

  • 高效接口测试:Python自动化框架设计与实现
  • 深度神经网络下的风格迁移模型(C#)
  • 【第七在线】数据分析与人工智能在商品计划中的应用
  • ES-mapping
  • HBase 集群搭建
  • 复杂网络与嵌入式领域结合方向
  • css 美化滚动条样式
  • ruoyi若依前后端分离版部署centos7服务器(全)
  • Vue如何请求接口——axios请求
  • 第六章[字典]:6.4:字典推导式
  • OD Linux发行版本
  • JavaOOP篇----第十四篇
  • leetcode 131. 分割回文串
  • Uniapp + Vue3 封装请求工具挂载全局
  • windows平台配置vsCode_CMake_Clang/LLVM_ninja环境与测试
  • 4. 路由到控制器 - Laravel从零开始教程
  • android高仿小视频、应用锁、3种存储库、QQ小红点动画、仿支付宝图表等源码...
  • Angular js 常用指令ng-if、ng-class、ng-option、ng-value、ng-click是如何使用的?
  • Create React App 使用
  • css的样式优先级
  • ES学习笔记(10)--ES6中的函数和数组补漏
  • GitUp, 你不可错过的秀外慧中的git工具
  • iOS编译提示和导航提示
  • jquery cookie
  • js中forEach回调同异步问题
  • PermissionScope Swift4 兼容问题
  • scrapy学习之路4(itemloder的使用)
  • ⭐ Unity 开发bug —— 打包后shader失效或者bug (我这里用Shader做两张图片的合并发现了问题)
  • vue学习系列(二)vue-cli
  • vue中实现单选
  • 动手做个聊天室,前端工程师百无聊赖的人生
  • 使用 @font-face
  • 首页查询功能的一次实现过程
  • 物联网链路协议
  • 转载:[译] 内容加速黑科技趣谈
  • kubernetes资源对象--ingress
  • ​什么是bug?bug的源头在哪里?
  • # 透过事物看本质的能力怎么培养?
  • #FPGA(基础知识)
  • #Js篇:单线程模式同步任务异步任务任务队列事件循环setTimeout() setInterval()
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • $.ajax()方法详解
  • (12)目标检测_SSD基于pytorch搭建代码
  • (2021|NIPS,扩散,无条件分数估计,条件分数估计)无分类器引导扩散
  • (PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
  • (定时器/计数器)中断系统(详解与使用)
  • (仿QQ聊天消息列表加载)wp7 listbox 列表项逐一加载的一种实现方式,以及加入渐显动画...
  • (附源码)springboot宠物医疗服务网站 毕业设计688413
  • (六)软件测试分工
  • (中等) HDU 4370 0 or 1,建模+Dijkstra。
  • (转)Oracle存储过程编写经验和优化措施
  • (转载)深入super,看Python如何解决钻石继承难题
  • *setTimeout实现text输入在用户停顿时才调用事件!*
  • *ST京蓝入股力合节能 着力绿色智慧城市服务
  • .bat批处理(二):%0 %1——给批处理脚本传递参数