Vue 2和Vue 3透传Attributes特性

Vue 2和Vue 3在透传Attributes方面存在一些区别,这些区别主要体现在对Attributes的处理方式和灵活性上。

  1. 在Vue 2中,当父组件向子组件传递Attributes时,这些Attributes会自动绑定到子组件的根元素上。这意味着,如果父组件为子组件提供了一个class或style等属性,这些属性将直接应用于子组件的根DOM元素。然而,Vue 2并没有提供太多的配置选项来精确控制这种透传行为。

默认透传

<!-- 父组件 -->  
<template>  <ChildComponent class="parent-class" data-custom="value" />  
</template>  
<script>  
import ChildComponent from './ChildComponent.vue';  export default {  components: {  ChildComponent  }  
};  
</script>  <!-- 子组件 ChildComponent.vue -->  
<template>  <div>Child Component</div>  
</template>  
<script>  
export default {  // 不需要任何配置,class和data-custom会自动绑定到<div>元素上  
};  
</script>
  1. 相比之下,Vue 3在透传Attributes方面提供了更多的灵活性和控制力。首先,Vue 3依然支持Attributes的自动透传,即父组件传递的Attributes会默认绑定到子组件的根元素上。但是,Vue 3增加了一个重要的选项:inheritAttrs通过设置inheritAttrs: false,开发者可以禁用Attributes的自动透传,从而更精细地控制哪些Attributes应该被透传。

使用inheritAttrs: false禁用自动透传

<!-- 子组件 ChildComponent.vue -->  
<template>  <div>Child Component</div>  
</template>  <script>  
export default {  inheritAttrs: false, // 禁用自动透传  // 你现在可以通过$attrs访问到这些透传的属性,并手动绑定它们  
};  
</script>
  1. 禁用自动透传后,开发者可以通过$attrs对象在子组件内部手动访问和处理这些透传的Attributes。这使得开发者能够更灵活地决定哪些Attributes应该被应用到子组件的哪个元素上,或者是否需要进行额外的处理或转换。

手动处理$attrs

<!-- 子组件 ChildComponent.vue -->  
<template>  <div :class="$attrs.class">Child Component</div>  
</template>  <script>  
export default {  inheritAttrs: false,  mounted() {  console.log(this.$attrs); // 输出透传的Attributes对象  }  
};  
</script>
  1. Vue 3的Composition API特性,提供了更强大的逻辑复用能力。在Composition API中,开发者可以通过setup函数和相关的响应式状态管理来更直接地处理Attributes。这使得透传Attributes的逻辑可以与组件的其他逻辑更紧密地集成在一起,提高了代码的可维护性和复用性。

通过Props传递Attributes

虽然$attrs主要用于处理未被识别为props的Attributes,但你也可以选择将某些Attributes作为props显式传递给子组件。

<!-- 父组件 -->  
<template>  <ChildComponent custom-prop="value" />  
</template>  <script>  
import ChildComponent from './ChildComponent.vue';  export default {  components: {  ChildComponent  }  
};  
</script>  <!-- 子组件 ChildComponent.vue -->  
<template>  <div :class="customPropClass">Child Component</div>  
</template>  
<script>  
export default {  props: {  customProp: {  type: String,  default: ''  }  },  computed: {  customPropClass() {  // 根据props计算class  return this.customProp;  }  }  
};  
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/732180.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c++ 常用的STL

前言 写这篇博客目的是为了记录在刷算法题中使用过的STL&#xff0c;因为有些不太常用的会遗忘。这篇博客只是作为笔记&#xff0c;不是详细的STL&#xff0c;因此只会对常用方法说明&#xff0c;不会详细介绍。此外在后面用到新的STL内容时会再补充。 列队 基础列队 基本列…

JsonUtility和LitJson的特点与区别

JsonUtility 和 LitJson 都是在 Unity 中用于处理 JSON 数据的工具&#xff0c;它们各自有一些特点和不足。 JsonUtility: 特点&#xff1a; Unity内置支持&#xff1a; JsonUtility 是 Unity 引擎内置的 JSON 序列化和反序列化工具&#xff0c;无需额外的依赖。 简单易用&…

【python】time库知识整理

简介 python的time库是python内置库&#xff0c;主要负责处理与时间相关的事务。 获取当前时间 函数作用time()获取当前时间戳ctime()获取字符串形式的时间gmtime()调用内部方法&#xff0c;赋予属性&#xff0c;能够被程序调用执行 time返回的是时间戳 ctime是返回的我们…

MPU6050详解

文章目录 前言MPU6050简介MPU6050参数 硬件电路MPU6050框图电荷泵的原理 内部时钟生成需要使用的寄存器&#xff08;常用&#xff09;采样率划分器配置寄存器陀螺仪配置寄存器加速度计配置寄存器加速度计测量寄存器温度测量寄存器陀螺仪测量寄存器电源管理1寄存器电源管理2寄存…

Tomcat实现java博客项目、状态页及常见配置介绍

目录 一、自建博客 1. 项目背景 2. 操作示例 二、状态页 1. 概述 2. server status 信息状态页 3. manager app 项目管理状态页 4. host manger 虚拟主机管理状态页 三、常见配置 1. 端口8005/tcp安全配置管理 2. tomcat端口号 3. 虚拟主机设置 4. Context配置 一…

R语言自定义颜色

一、创建颜色梯度&#xff08;渐变色&#xff09; 在绘热图时&#xff0c;需要将数值映射到不同的颜色上&#xff0c;这时就需要一系列的颜色梯度colorRampPalette 函数支持自定义的创建一系列的颜色梯度。 代码示例&#xff1a; library(RColorBrewer)x <- colorRampPal…

【kubernetes】关于k8s集群的pod控制器

目录 一、deployment控制器 二、statefulset控制器 1、验证数据可以持久化 2、验证删除后名称不会改变&#xff0c;数据还会一直存在 3、验证扩容的创建过程是升序串行执行&#xff0c;并且自动创建pv 4、验证滚动更新的时候也是升序执行&#xff0c;数据持久化还在 5、验…

【排序算法】深入理解归并排序算法:从原理到实现

目录 1. 引言 2. 归并排序算法原理 3. 归并排序的时间复杂度分析 4. 归并排序的应用场景 5. 归并排序的优缺点分析 5.1 优点&#xff1a; 5.2 缺点&#xff1a; 6. Java、JavaScript 和 Python 实现归并排序算法 6.1 Java 实现&#xff1a; 6.2 JavaScript 实现&…

A5自媒体wordpress主题模板

一个简洁的wordpress个人博客主题&#xff0c;适合做个人博客&#xff0c;SEO优化效果挺不错的。 https://www.wpniu.com/themes/204.html

什么是ETL?什么是ELT?怎么区分它们使用场景

在大数据处理的领域中&#xff0c;ETL和ELT是两个经常被数据工程师提到的工具&#xff0c;而有很多数据工程师对这两种工具的区别和使用和定位有一定的模糊&#xff0c;其实它们分别代表了两种不同的数据集成方法。尽管这两种方法看起来都是从源系统提取数据&#xff0c;转换数…

2024AI在医疗领域中的辅助趋势与现有进展

2024 年 AI 辅助研发趋势随着人工智能技术的持续发展与突破&#xff0c;2024年AI辅助研发正成为科技界和工业界瞩目的焦点。从医药研发到汽车设计&#xff0c;从软件开发到材料科学&#xff0c;AI正逐渐渗透到研发的各个环节&#xff0c;变革着传统的研发模式。在这一背景下&am…

rabbitmq 基本总结

rabbitmq 的基本概念 vhost、broker、producer、 consumer、 exchange、 queue、 routing key rabbitmq 常用的队列类型&#xff0c;工作队列&#xff08;简单队列&#xff09;,pub/sub, routing key&#xff0c; topic 模式 <dependency><groupId>com.rabbitmq&l…

启动项目报502怎么处理呢?

您好&#xff0c;我是码农飞哥&#xff08;wei158556&#xff09;&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f4aa;&#x1f3fb; 1. Python基础专栏&#xff0c;基础知识一网打尽&#xff0c;9.9元买不了吃亏&#xff0c;买不了上当。 Python从入门到精…

蓝桥杯练习系统(算法训练)ALGO-982 最小距离

资源限制 内存限制&#xff1a;256.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 最小距离 问题描述 数轴上有n个数字&#xff0c;求最近的两个数&#xff0c;即min(abs(x-y)) 输入格式 第一行包含一个整数n。   …

Cpp(Python)和MATLAB差动驱动ROS Raspberry Pi全功能机器人原型

要点 使用代码语言C、XML、Python和YAMLC处理&#xff1a;创建ROS包&#xff0c;创建ROS节点&#xff08;C&#xff09;&#xff0c;添加自定义信息和服务文件&#xff0c;使用ROS服务&#xff08;C&#xff09;&#xff1a;创建ROS动作服务器和客户端&#xff08;C&#xff0…

Redis的Lua脚本

Redis提供了Lua脚本功能&#xff0c;在一个脚本中编写多条Redis命令&#xff0c;确保多条redis命令执行时的原子性。&#xff08;让判断线程标识和释放锁原子执行&#xff09; 1.下载lua插件 2.创建lua文件 3.调用lua脚本 public void unlock() {//调用lua脚本原子性的判断线…

CSS中元素的层叠顺序

层叠顺序&#xff0c;英文称作 stacking order&#xff0c;表示元素发生层叠时有着特定的垂直显示顺序。下面是盒模型的层叠规则&#xff1a; 对于上图&#xff0c;由上到下分别是&#xff1a; &#xff08;1&#xff09;背景和边框&#xff1a;建立当前层叠上下文元素的背景…

【Qt】四种绘图设备详细使用

绘图设备有4个: **绘图设备是指继承QPainterDevice的子类————**QPixmap QImage QPicture QBitmap(黑白图片) QBitmap——父类QPixmapQPixmap图片类&#xff0c;主要用来显示&#xff0c;它针对于显示器显示做了特殊优化&#xff0c;依赖于平台的&#xff0c;只能在主线程…

Linux系统——web服务拓展练习

目录 一、实验环境搭建 1. Centos 7-5——Client 2. Centos 7-1——网关服务器 3. Centos 7-2——Web1 4. Centos 7-3——Web2 5. Centos 7-4——Nginx 二、在Nginx服务器上搭建LNMP服务&#xff0c;并且能够对外提供Discuz论坛服务&#xff1b;在Web1、Web2服务器上搭建…

数据集下载汇总

国家数据网 https://data.stats.gov.cn/ 国家数据是国家统计局发布统计信息的网站&#xff0c;包含了我国经济、民生、农业、工业、运输、旅游、教育、科技、卫生等多个方面的数据&#xff0c;并且在月度、季度、年度都有覆盖&#xff0c;较为全面和权威&#xff0c;对于社会…