vue入门教程:组件透传 Attributes

server/2024/12/23 11:42:38/

一、透传Attributes的基本概念

透传Attributes指的是传递给一个组件,但没有被该组件声明为props或emits的attribute或者v-on事件监听器。最常见的例子包括class、style和id。当一个组件以单个元素为根路径渲染时,透传的attribute会自动被添加到根元素上。

二、透传Attributes的工作原理

  1. 自动透传

    • 当子组件以单个元素为根元素时,父组件中未被子组件声明为props或emits的attribute会自动透传到子组件的根元素上。
  2. 多根节点情况

    • 在Vue 3中,组件可以包含多个根节点。当组件存在多个根节点时,透传的attribute不会自动添加到任何根元素上,而是需要通过v-bind="$attrs"手动指定绑定到哪个根节点上。

三、透传Attributes的使用场景

  1. 样式和类名传递

    • 父组件可以将class、style等样式相关的attribute透传给子组件,以实现样式的动态传递和复用。
  2. 事件监听器传递

    • 父组件可以将v-on事件监听器透传给子组件,以便在子组件中触发父组件定义的事件处理函数。
  3. 隔代通讯

    • 在组件树中,透传Attributes可以用于实现隔代组件之间的通讯,而无需通过中间组件手动传递props。

四、透传Attributes的禁用与自定义

  1. 禁用透传

    • 如果不希望子组件自动继承父组件透传过来的属性,可以在子组件的setup函数中使用defineOptions宏设置inheritAttrs: false。这样,透传的attribute就不会自动添加到子组件的根元素上。
  2. 自定义透传

    • 即使禁用了自动透传,仍可以通过在模板中使用v-bind="$attrs"将透传的attribute手动绑定到子组件的某个元素上。此外,还可以使用useAttrs组合式API来访问透传进来的所有attribute。

五、示例代码

以下是一个使用组合式API和透传Attributes的示例代码:

<!-- Parent.vue -->
<template><div><Child class="parent-class" @click="handleClick" /></div>
</template><script setup>
import { ref } from 'vue';
import Child from './Child.vue';const handleClick = () => {console.log('Parent click handler');
};
</script>
<!-- Child.vue -->
<template><div class="child-class" v-bind="$attrs" @click="handleClick"><slot></slot></div>
</template><script setup>
import { useAttrs } from 'vue';const attrs = useAttrs();const handleClick = () => {console.log('Child click handler');// 调用父组件透传过来的click事件处理函数if (attrs.onClick) {attrs.onClick();}
};// 禁用自动透传(可选)
defineOptions({inheritAttrs: false,
});
</script>

在这个例子中,Parent组件将class属性和click事件监听器透传给了Child组件。在Child组件中,通过v-bind="$attrs"将透传的class属性手动绑定到了根元素上,并通过访问attrs.onClick调用了父组件透传过来的click事件处理函数。同时,Child组件还定义了自己的handleClick函数,它会在点击事件发生时先被调用,然后再调用父组件的click事件处理函数。

六、注意事项

  1. 避免冲突

    • 当子组件本身已经定义了与透传属性同名的prop或事件监听器时,需要注意避免冲突。可以通过在子组件中显式声明这些prop或事件监听器来覆盖透传的属性。
  2. 性能考虑

    • 在大规模应用中,透传大量属性可能会影响性能。因此,在不需要时应及时禁用透传或优化透传属性的使用方式。
  3. 可读性和可维护性

    • 过度使用透传属性可能会降低代码的可读性和可维护性。因此,在设计时应权衡利弊,合理使用透传属性。

http://www.ppmy.cn/server/152480.html

相关文章

RFdiffusion get_torsions函数解读

函数功能 get_torsions 函数根据输入的原子坐标(xyz_in)和氨基酸序列(seq),计算一组主链和侧链的扭转角(torsions)。同时生成备用扭转角(torsions_alt),用于表示可以镜像翻转的几何结构,并返回掩码(tors_mask)和是否平面化(tors_planar)的信息。 输入参数 xyz…

本机如何连接虚拟机MYSQL

要让本机&#xff08;主机&#xff09;连接到虚拟机上的 MySQL 数据库&#xff0c;你需要确保虚拟机和主机之间的网络连接正常&#xff0c;并且 MySQL 配置允许外部连接。以下是实现本机连接虚拟机 MySQL 的步骤&#xff1a; 步骤 1&#xff1a;确认虚拟机与本机的网络连接 确…

FastAPI vs Go 性能对比分析

FastAPI vs Go 性能对比分析 总体结论 FastAPI 虽然性能优秀&#xff0c;但整体上仍无法完全达到 Go 的性能水平。 详细对比 优势 FastAPI 开发效率高Python生态系统丰富自动API文档生成类型检查和验证异步支持好 Go 原生性能更强内存占用更低并发处理能力强编译型语言的优…

防火墙规则配置错误导致的网络问题排查

防火墙规则配置错误可能导致服务器的网络中断、服务不可用或访问受限等问题。排查和修复防火墙规则配置错误需要系统性的方法&#xff0c;以快速定位问题并恢复正常服务。以下是防火墙规则配置错误导致网络问题的排查与解决指南。 一、常见防火墙配置错误及其影响 错误的默认策…

vue3+vite 引入动画组件库 Inspira UI

关于Inspira UI Inspira UI不是传统的组件库。相反&#xff0c;它是精选的优雅组件集合&#xff0c;您可以轻松将其集成到您的应用程序中。只需选择所需的组件&#xff0c;复制代码&#xff0c;然后自定义以适合您的项目即可。您可以随意使用和修改代码&#xff01; 官网地址…

【hackmyvm】eigthy 靶机wp

tags: HMVgopherdoas另类sudo提权knock目录穿越 Type: wp dg-publish: true 难度: ⭐️⭐️⭐️ 作者: sml 系统: Linux 这里写目录标题 2. 信息收集2.1. 端口扫描2.2. knock敲门2.3. 目录扫描2.4. 目录穿越 3. 提权 2. 信息收集 2.1. 端口扫描 ┌──(root㉿kali)-[~/Deskt…

关于VQ-GAN利用滑动窗口生成 高清图像

参考文章&#xff1a;VQGAN 论文与源码解读&#xff1a;前Diffusion时代的高清图像生成模型 | 周弈帆的博客 概念补充&#xff1a;所谓“高清”&#xff0c;就是像素很多&#xff0c;比如&#xff0c;512x512就比64x64要高清很多 请仔细琢磨上面的这几句话即可。 &#xff08;…

Linux查看键鼠输入

文章目录 通过打开input设备来读取输入通过第三方程序获取xevxinputevtest 参考 本文简单介绍几种在linux下查看键鼠输入的方法 通过打开input设备来读取输入 程序如下&#xff0c;使用时需要看情况修改input设备路径 #include <fcntl.h> #include <linux/input.h&g…