vue3的attr透传属性详解和使用法方式。以及在css样式的伪元素中实现
在 Vue 3 和 TypeScript 中,属性透传(attr pass-through)是指将组件的属性传递到其根元素或某个子元素中。这个概念在开发可复用的组件时非常有用,尤其是当你希望将父组件的属性动态地传递给子组件的某个 DOM 元素时。
在 Vue 3 中,透传属性通常使用 v-bind="$attrs" 结合 v-on="$listeners" 来实现。对于 CSS 样式中的伪元素,你可以通过 ::before、::after 等伪元素来实现样式效果。
下面我将详细解释 Vue 3 中如何实现属性透传以及如何在 CSS 样式的伪元素中使用。
1. Vue 3 属性透传 (Attribute Pass-Through)
基本概念
在 Vue 中,$attrs 是一个包含父组件传递给子组件的所有属性的对象(不包括 class 和 style)。这些属性可以通过 v-bind="$attrs" 来透传到子组件的根元素或某个特定元素。
$listeners (在 Vue 2 中称为 $on)用于监听父组件传递的事件,也可以通过 v-on="$listeners" 传递给子组件的元素。
例子:属性透传
假设你有一个 Button 组件,想要让父组件传递任何属性给 button 元素,比如 type 或 disabled。
Button.vue(子组件)
<template><!-- 使用 $attrs 将所有传递给该组件的属性透传到 button 元素 --><button v-bind="$attrs" v-on="$listeners"><slot></slot></button>
</template><script lang="ts">
import { defineComponent } from 'vue';export default defineComponent({name: 'Button',// 此处我们可以定义 props,$attrs 会包括除了 props 之外的所有传递的属性props: {label: {type: String,required: true,}}
});
</script>
Parent.vue(父组件)
<template><!-- 父组件传递属性到 Button 组件 --><Button type="submit" disabled>Submit</Button>
</template><script lang="ts">
import { defineComponent } from 'vue';
import Button from './Button.vue';export default defineComponent({components: {Button,}
});
</script>
在这个例子中,Button 组件接收到的 type="submit" 和 disabled 属性会被透传到最终的 <button> 元素上。
注意事项
$attrs只包含父组件传递给子组件的属性(不包括class和style,这些属性会被自动透传)。- 如果组件定义了自己的
props,传递给子组件的属性不会自动作为props接收,必须显式通过v-bind="$attrs"传递。
2. 在 CSS 伪元素中实现属性透传
CSS 伪元素(如 ::before 和 ::after)允许我们为元素添加样式和内容。我们可以通过 Vue 组件的 style 或 class 来间接影响伪元素的样式。
基本的伪元素使用
假设我们要为一个按钮添加文本前缀或后缀,通过 CSS 伪元素来实现:
Button.vue(子组件)
<template><button class="button" v-bind="$attrs"><slot></slot></button>
</template><style scoped>
.button {position: relative;padding-left: 20px;
}.button::before {content: attr(data-prefix);position: absolute;left: 0;top: 50%;transform: translateY(-50%);
}.button::after {content: attr(data-suffix);position: absolute;right: 0;top: 50%;transform: translateY(-50%);
}
</style><script lang="ts">
import { defineComponent } from 'vue';export default defineComponent({name: 'Button',props: {label: String,}
});
</script>
在这个例子中,我们使用了 CSS ::before 和 ::after 来实现伪元素,并通过 data-* 属性将父组件传递的数据用于伪元素内容。
Parent.vue(父组件)
<template><!-- 在父组件中,我们通过自定义属性传递值 --><Button data-prefix="Start" data-suffix="End" label="Click Me">Button</Button>
</template><script lang="ts">
import { defineComponent } from 'vue';
import Button from './Button.vue';export default defineComponent({components: {Button,}
});
</script>
解释
- 在
Button.vue中,::before和::after伪元素通过content: attr(data-prefix)和content: attr(data-suffix)读取传递的自定义属性 (data-prefix和data-suffix)。 - 在
Parent.vue中,父组件传递了data-prefix和data-suffix属性,它们将会影响按钮的伪元素内容。
结合 v-bind 和 ::before、::after
你还可以通过 v-bind="$attrs" 将属性传递给根元素,从而在根元素上动态地设置样式或其他属性。这可以进一步影响伪元素的样式。
<template><button class="button" v-bind="$attrs"><slot></slot></button>
</template><style scoped>
.button {position: relative;
}.button::before {content: attr(data-content);position: absolute;left: 0;top: 50%;transform: translateY(-50%);
}
</style><script lang="ts">
import { defineComponent } from 'vue';export default defineComponent({name: 'Button',props: {label: String,}
});
</script>
父组件传递 data-content:
<template><Button data-content="Hello World!">Click Me</Button>
</template>
总结
- 属性透传:使用
v-bind="$attrs"和v-on="$listeners"实现将父组件的属性和事件传递给子组件的 DOM 元素。 - 伪元素使用:CSS 伪元素(如
::before和::after)可用attr()函数从元素的属性(如data-*属性)中提取内容并显示在页面上。
相关文章:
vue3的attr透传属性详解和使用法方式。以及在css样式的伪元素中实现
在 Vue 3 和 TypeScript 中,属性透传(attr pass-through)是指将组件的属性传递到其根元素或某个子元素中。这个概念在开发可复用的组件时非常有用,尤其是当你希望将父组件的属性动态地传递给子组件的某个 DOM 元素时。 在 Vue 3 …...
【仿真建模-MESA】框架简介
1. 简介 Mesa是一个基于Python3的开源项目,旨在提供一个现代、易用的多智能体仿真环境。它借鉴了NetLogo、Repast和MASON等多智能体仿真框架的优点,并结合Python语言的强大功能,为用户提供了丰富的建模和仿真工具。 《官方文档》 2. 核心组件…...
Linux环境基础开发工具的使用(yum、vim、gcc、g++、gdb、make/Makefile)
目录 Linux软件包管理器 - yum Linux下安装软件包的方式 认识yum 查找软件包 安装软件 如何实现本地机器和云服务器之间的文件互传 卸载软件 Linux编辑器 - vim vim的基本概念 vim下各模式的切换 批量化注释 vim的简单配置 Linux编译器 - gcc/g gcc/g的作用 gcc/g语…...
VSCode 间距太小
setting->font family 使用:Consolas, Courier New, monospace 字体...
【K8S系列】imagePullSecrets配置正确,但docker pull仍然失败,进一步排查详细步骤
如果 imagePullSecrets 配置正确,但在执行 docker pull 命令时仍然失败,可能存在以下几种原因。以下是详细的排查步骤和解决方案。 1. 检查 Docker 登录凭证 确保你使用的是与 imagePullSecrets 中相同的凭证进行 Docker 登录: 1.1 直接登录 在命令行中,执行以下命令: …...
【ARM Coresight OpenOCD 系列 5.1 -- OpenOCD 无法识别CPUID 问题: xxx is unrecognized】
请阅读【嵌入式开发学习必备专栏】 文章目录 OpenOCD 无法识别CPUID 问题ARM CPUIDCPUID 特性CPUID 寄存器字段OpenOCD 无法识别CPUID 问题 在使用OpenOCD 进行CPU debug的过程中有时会报出 无法识别CPUID的问题,本文将会介绍如何解决这个问题。首先我们来学习下什么是CPUID,…...
如何实现点击目录跳转到指定位置?【vue】
需求:实现目录点击跳转到指定位置,点击后直接定位到指定模块 效果: 实现方法: (1)a标签跳转 普通使用: <!DOCTYPE html> <html><head><title>a-Demo</title>&l…...
SQL 通配符
SQL 通配符 在SQL中,通配符是一种特殊字符,用于在LIKE子句中搜索数据。它们主要用于模式匹配,允许你搜索符合特定模式的值。SQL中的通配符通常用于SELECT、UPDATE和DELETE语句中,以增加查询的灵活性。本文将详细介绍SQL中常用的通…...
ubuntu显示管理器_显示导航栏
ubuntu文件管理器_显示导航栏 一、原始状态: 二、显示导航栏状态: 三、原始状态--->导航栏状态: 1、打开dconf编辑器,直接在搜索栏搜索 dconf-editor ------如果没有安装,直接按流程安装即可。 2、进入目录:org …...
黑芝麻嵌入式面试题及参考答案
请详细描述二叉树的深度优先搜索(dfs)流程。 深度优先搜索是一种用于遍历二叉树的重要算法,主要有先序遍历、中序遍历和后序遍历三种方式。 先序遍历的流程是,首先访问根节点,然后递归地遍历左子树,最后递归地遍历右子树。这就好比是在探索一个家族树,先拜访家族中的长辈…...
使用 PyTorch-BigGraph 构建和部署大规模图嵌入的完整教程
当涉及到图数据时,复杂性是不可避免的。无论是社交网络中的庞大互联关系、像 Freebase 这样的知识图谱,还是推荐引擎中海量的数据量,处理如此规模的图数据都充满挑战。 尤其是当目标是生成能够准确捕捉这些关系本质的嵌入表示时,…...
系统性能优化方法论详解:从理解系统到验证迭代
在当今的企业级和云计算环境中,系统性能优化已成为提升竞争力的关键因素。本文将对系统优化的步骤进行深入解析,帮助读者系统化地进行性能优化,从而显著提升系统的整体表现。 流程概述: 系统性能优化的流程可以分为以下几个关键步骤&#x…...
使用Tengine 对负载均衡进行状态检查(day028)
本篇文章对于在服务器已经安装了nginx,但却希望使用Tengine 的状态检查或其他功能时使用,不需要卸载服务器上的nginx,思路是使用干净服务器(未安装过nginx)通过编译安装Tengine,通过对./configure的配置,保证安装Tengi…...
网站推广实战案例:杭州翔胜科技有限公司如何为中小企业打开市场大门
以下是以杭州翔胜科技有限公司为例,解析其如何通过网站推广为中小企业打开市场大门的实战案例: 一、一站式网站推广方案 杭州翔胜科技有限公司提供一站式网站推广方案,该方案整合了多种推广手段,如搜索引擎优化(SEO&a…...
视频修复技术和实时在线处理
什么是视频修复? 视频修复技术的目标是填补视频中的缺失部分,使视频内容连贯合理。这项技术在对象移除、视频修复和视频补全等领域有着广泛的应用。传统方法通常需要处理整个视频,导致处理速度慢,难以满足实时处理的需求。 技术发…...
文心一言 VS 讯飞星火 VS chatgpt (396)-- 算法导论25.2 1题
一、在图 25-2 所示的带权重的有向图上运行 Floyd-Warshall 算法,给出外层循环的每一次迭代所生成的矩阵 D ( k ) D^{(k)} D(k) 。如果要写代码,请用go语言。 文心一言: 好的,让我们一步步分析在带权重的有向图上运行 Floyd-Wa…...
如何使用本地大模型做数据分析
工具:interpreter --local 样本数据: 1、启动分析工具 2、显示数据文件内容 输入: 显示/Users/wxl/work/example_label.csv 输出:(每次输出的结果可能会不一样) 3、相关性分析 输入: 分析客户类型与成…...
【Nginx从入门到精通】04-安装部署-使用XShell给虚拟机配置静态ip
文章目录 总结1、XShell :方便管理多台机器2、配置ip文件:区分大小写 一、查看上网模式二、Centos 7 设置静态ipStage 1 :登录root账号Stage 2 :设置静态ip : 修改配置文件 <font colororange>ifcfg-ens33Stage 2-1…...
C# 面向对象的接口
接口,多态性,密封类 C# 接口 遥控器是观众和电视之间的接口。 它是此电子设备的接口。 外交礼仪指导外交领域的所有活动。 道路规则是驾车者,骑自行车者和行人必须遵守的规则。 编程中的接口类似于前面的示例。 接口是: APIsC…...
使用IDEA+Maven实现MapReduced的WordCount
使用IDEAMaven实现MapReduce 准备工作 在桌面创建文件wordfile1.txt I love Spark I love Hadoop在桌面创建文件wordfile2.txt Hadoop is good Spark is fast上传文件到Hadoop # 启动Hadoop cd /usr/local/hadoop ./sbin/start-dfs.sh # 删除HDFS的hadoop对应的input和out…...
量子增强生成模型革新格点场理论计算
1. 量子增强生成模型在格点场理论中的突破性应用在计算物理领域,特别是高能物理研究中,格点场理论(Lattice Field Theory, LFT)一直是研究非微扰量子场论的重要工具。传统方法如马尔可夫链蒙特卡洛(MCMC)虽…...
Saleor:应对现代电商架构挑战的无头商业引擎解决方案
Saleor:应对现代电商架构挑战的无头商业引擎解决方案 【免费下载链接】saleor Saleor Core: the high performance, composable, headless commerce API. 项目地址: https://gitcode.com/gh_mirrors/sa/saleor 在数字化转型浪潮中,电商平台面临的…...
Creality Print:从新手到专家的完整3D打印切片软件指南
Creality Print:从新手到专家的完整3D打印切片软件指南 【免费下载链接】CrealityPrint 项目地址: https://gitcode.com/gh_mirrors/cr/CrealityPrint 在3D打印的世界里,切片软件是连接数字模型与物理实体的关键桥梁。无论您刚刚接触3D打印&…...
技术深度解析:OpenUtau多语言音素处理架构与实现原理
技术深度解析:OpenUtau多语言音素处理架构与实现原理 【免费下载链接】OpenUtau Open singing synthesis platform / Open source UTAU successor 项目地址: https://gitcode.com/gh_mirrors/op/OpenUtau OpenUtau作为开源歌声合成平台,其多语言支…...
Python量化投资终极指南:MOOTDX让通达信数据获取变得如此简单
Python量化投资终极指南:MOOTDX让通达信数据获取变得如此简单 【免费下载链接】mootdx 通达信数据读取的一个简便使用封装 项目地址: https://gitcode.com/GitHub_Trending/mo/mootdx 还在为股票数据的获取而烦恼吗?你是否曾经花费数小时研究复杂…...
10分钟快速上手:使用html-to-docx实现HTML到Word文档的无缝转换
10分钟快速上手:使用html-to-docx实现HTML到Word文档的无缝转换 【免费下载链接】html-to-docx HTML to DOCX converter 项目地址: https://gitcode.com/gh_mirrors/ht/html-to-docx 还在为网页内容无法完美转换为Word文档而烦恼吗?每次复制粘贴H…...
ColabFold终极指南:5分钟免费预测蛋白质三维结构
ColabFold终极指南:5分钟免费预测蛋白质三维结构 【免费下载链接】ColabFold Making Protein folding accessible to all! 项目地址: https://gitcode.com/gh_mirrors/co/ColabFold 想要探索蛋白质的神秘世界却苦于没有高性能计算设备?ColabFold为…...
C#字节序反转:从原理到工业级实现
1. 字节序反转不是“字节倒序”,而是数据语义的精准翻转很多人第一次看到“字节序反转”这个词,下意识就去写Array.Reverse(bytes)——结果一测发现:整数读出来完全不对。我去年在做工业PLC通信协议解析时就栽过这个跟头:设备返回…...
GM-CSF (54-78) ;CLQTRLELYKQGLRGSLTKLKGPLT
一、基础信息中文名称:粒细胞 - 巨噬细胞集落刺激因子片段 (54-78)英文名称:Granulocyte-Macrophage Colony-Stimulating Factor (54-78)三字母序列:Cys-Leu-Gln-Thr-Arg-Leu-Glu-Leu-Tyr-Lys-Gln-Gly-Leu-Arg-Gly-Ser-Leu-Thr-Lys-Leu-Lys-G…...
抖音内容保存技术方案:开源下载工具深度解析与应用实践
抖音内容保存技术方案:开源下载工具深度解析与应用实践 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback supp…...
