Vue3:$attrs实现组件通信

news2025/1/11 20:42:38

目录

一.性质

1.响应式

2.包含所有非prop属性

3.动态属性

二.作用

1.访问非prop属性

2.灵活性

3.组件重用

三.使用

1.爷爷组件

2.父亲组件

3.儿子组件

四.代码

1.爷爷组件代码

2.父亲组件代码

3.孙子组件代码

五.效果图


在Vue 3中,$attrs 是一个响应式对象,它包含了父组件传递给子组件的所有非prop属性。(爷-->孙)

一.性质

1.响应式

$attrs 是一个响应式对象,这意味着当父组件的数据发生变化时,子组件中的 $attrs 也会相应地更新。

2.包含所有非prop属性

$attrs 包含了所有传递给子组件的属性,除了那些显式定义为prop的属性。

3.动态属性

$attrs 中的属性名称是动态的,它反映了父组件传递给子组件的属性名。

二.作用

1.访问非prop属性

子组件可以通过 $attrs 访问从父组件传递下来的所有非prop属性,而不需要显式地在props中声明它们。

2.灵活性

使用 $attrs 可以提高组件的灵活性,因为子组件不需要知道父组件传递了哪些属性,它可以直接使用这些属性。

3.组件重用

当组件被重用时,它不需要修改以适应不同的父组件属性,因为它可以通过 $attrs 接收这些属性。

三.使用

1.爷爷组件

这段代码创建了一个界面,展示爷爷的个人信息,并允许通过 update函数与 father 组件进行交互,更新爷爷的姓名。father 组件接收到 namecar 和 price 的值,并可能根据这些值进行相应的操作。通过这种方式,两个组件之间实现了数据的传递和响应。

2.父亲组件

<son v-bind="$attrs"/>:这里使用 v-bind 指令将当前组件的所有属性($attrs)绑定到 son 组件上。$attrs 是一个包含所有非 prop 属性的对象。

3.儿子组件

接收 namecar, 和 price 作为属性,并通过模板显示这些信息。此外,包含一个按钮,当点击时,会调用 update 方法,并传入 '孙子' 参数给爷爷。

四.代码

1.爷爷组件代码

<template>

    <div class="grandpa">
        <h4>我是爷爷</h4>
        <h4>车主:{{ name }}</h4>
		<h4>car:{{ car }}</h4>
		<h4>price:{{ price }}w</h4>
    </div>
    <father :name="name"  v-bind="{car:'宝马',price:200}" :update="update"/>
</template>


<script setup lang="ts" name="grandpa">
import father from '../components/father.vue'

import { ref } from "vue";
	let name = ref('爷爷')
    let car = ref('宝马')
    let price = ref(200)

	function update(value:any){
		name.value = value
    } 

</script>

<style >
.grandpa {
  background-color: orange;
}


</style>

2.父亲组件代码

<template>

    <div class="father">
        <h4>我是爹</h4>  
    </div>

    <son v-bind="$attrs"/>
    
</template>

<script setup lang="ts" name="father">
import son from '../components/son.vue'

</script>


<style>
.father{
    background-color: skyblue;
}

h4{
    margin-left: 20px;
    font-size: 20px;
}

</style>

3.孙子组件代码

<template>
    <div class="son">
        <h4>我是儿子</h4>
        <h4>车主:{{ name }}</h4>
		<h4>car: {{ car }}</h4>
		<h4>price:{{ price }}w</h4>
		<button @click="update('孙子')">把车给孙子</button>
    </div>
</template>


<script setup lang="ts" name="son">
defineProps(['name','car','price','update'])

</script>


<style>
.son{
    background-color: beige;
}

h4{
    margin-left: 20px;
    font-size: 20px;
}
button{
    width: 120px;
    height: 60px;
    font-size: 20px;
    margin-left: 20px;
    border-width: 2px;
    border-color: red;
}
</style>

五.效果图

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

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

相关文章

string类的模拟实现以及oj题

前言 上篇博客实现了string类的begin()、end()、构造函数、析构函数、c_str、size()、clear()、capacity()、[ ]、reserve()、push_back、append()、insert()、。这篇博客实现剩下的一些重要功能。 string类的模拟实现 string.h #include<iostream> #include<stri…

稳了,搭建Docker国内源图文教程

大家好&#xff0c;之前分享了我的开源作品 Cloudflare Workers Proxy&#xff0c;它的作用是代理被屏蔽的地址&#xff0c;理论上支持代理任何被屏蔽的域名&#xff0c;使用方式也很简单&#xff0c;只需要设置环境变量 PROXY_HOSTNAME 为被屏蔽的域名&#xff0c;最后通过你的…

强化信息安全:密码机密钥管理的策略与实践

强化信息安全&#xff1a;密码机密钥管理的策略与实践 随着信息技术的飞速发展&#xff0c;信息安全已成为企业和社会关注的焦点。密码机作为加密通信和数据保护的关键设备&#xff0c;其密钥管理直接关系到整个信息系统的安全性。本文旨在探讨密码机密钥管理的策略与实践&…

如何根据协议请求去捕捉在个文件中发出去的

场景&#xff1a;随着业务越来越复杂&#xff0c;一个“触发”可能发出去N个协议&#xff0c;此时有某一个协议发生了报错&#xff0c;需要去找这个协议&#xff0c;去文件中走读逻辑&#xff0c;去找该协议&#xff0c;效率很慢&#xff0c;业务极其复杂的情况下&#xff0c;很…

渐变色代码主题你受得了吗

分享一个vscode编辑器的渐变色主题 效果图如下 vscode扩展搜索 gradient theme安装即可。

毕业设计选题:基于springboot+vue+uniapp的驾校报名小程序

开发语言&#xff1a;Java框架&#xff1a;springbootuniappJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#…

二级C语言2023-9易错题

1 二叉树结点数计算&#xff1a; 一棵二叉树有10个度为1的结点&#xff0c;7个度为2的结点&#xff0c;则该二叉树共有____个结点。 解&#xff1a; 2 指针&#xff1a; 有以下程序 #inctude<stdio.h> #include<stdlib.h> main() { int *a&#xff0c;*b&…

OpenHarmony(鸿蒙南向开发)——小型系统内核(LiteOS-A)【扩展组件】上

往期知识点记录&#xff1a; 鸿蒙&#xff08;HarmonyOS&#xff09;应用层开发&#xff08;北向&#xff09;知识点汇总 鸿蒙&#xff08;OpenHarmony&#xff09;南向开发保姆级知识点汇总~ 子系统开发内核 轻量系统内核&#xff08;LiteOS-M&#xff09; 轻量系统内核&#…

CSS01-语法规范、基础选择器

一、CSS语法规范 示例&#xff1a; 二、CSS的基础选择器 选择器(选择符)就是根据不同需求把不同的标签选出来这就是选择器的作用。 简单来说&#xff0c;就是选择标签用的。 选择器的分类&#xff1a; 1、标签选择器 2、类选择器&#xff08;开发最常用&#xff09; 长字符命名…

本地搭建我的世界服务器(JAVA)简单记录

网上参考教程挺多的&#xff0c;踩了不少坑&#xff0c;简单记录一下&#xff0c;我做的是一个私人服务器&#xff0c;就是和朋友3、4个人玩。 笨蛋 MC 开服教程 先放一个比较系统和完整的教程&#xff0c;萌新可用&#xff0c;这个教程很详细&#xff0c;我只是记录一下自己的…

相亲交友系统源码 连接你我,不再孤单

在这个数字时代&#xff0c;人们的生活方式已经发生了巨大的变化。随着工作压力增大和社会竞争激烈化&#xff0c;很多人发现自己很难有时间和机会去结识新的朋友&#xff0c;更不用说找到适合自己的伴侣了。相亲交友系统正是在这种背景下应运而生&#xff0c;它不仅简化了交友…

操作系统 | 学习笔记 | | 王道 | 5.2 设备独立软件

5.2 设备独立性软件 IO核心子系统 磁盘IO也属于IO调度问题 5.2.1 与设备无关的软件 与设备无关的软件是I/O系统的最高层软件&#xff0c;它的下层是设备驱动程序。 设备保护&#xff1a; 操作系统需要实现文件保护功能&#xff0c;不同的用户对各个文件有不同的访问权限&am…

BUUCTF-MISC-隐藏的钥匙

下载题目文件&#xff0c;获得了一张格式为jpg的路飞图片 按照习惯&#xff0c;首先使用十六进制编译器打开文件&#xff0c;这里我使用winhex打开文件 首先考虑有没有flag直接隐写在文件中&#xff0c;按照图示步骤查找flag字段 我们查到了flag&#xff0c;通过经验和图中base…

[Python]案例驱动最佳入门:股票分析 Python数据分析与可视化实战

在股票市场中&#xff0c;价格波动和投资决策紧密相连。通过数据分析&#xff0c;投资者可以识别市场趋势、价格波动背后的规律&#xff0c;并做出明智的投资决策。Python凭借其强大的数据处理和可视化功能&#xff0c;在金融市场分析中被广泛应用。本文将通过一个假设的股票市…

java踩坑

1.mybatis在idea可以正常运行&#xff0c;但是打jar包后&#xff0c;就报链接超时&#xff0c;可能是参数设置有问题&#xff0c;但是idea自动忽略了。 出问题的配置&#xff1a;&#xff08;圈出来的地方乱码了&#xff0c;idea有纠错能力&#xff0c;它自动调整为正确的&…

three.js shader 实现天空中白云

three.js shader 实现天空中白云 预览&#xff1a; https://threehub.cn/#/codeMirror?navigationThreeJS&classifyshader&idwhiteCloud 更多案例 可见 预览&#xff1a; https://threehub.cn import * as THREE from "three"; import { OrbitControls …

web基础—dvwa靶场(十二)JavaScript Attacks

JavaScript Attacks (前端攻击) 本章节中的攻击旨在帮助您了解如何在浏览器中使用 JavaScript 以及如何对其进行操作&#xff0c;攻击可以通过分析网络流量来实现&#xff0c;但这不是本章节的重点而且可能要困难得多。 只需提交单词 “success” 即可攻击成功&#xff0c;显然…

开石开放式耳机怎么样?南卡、开石、声阔开放式耳机测评

​作为一名多年的数码博主&#xff0c;我本人也是个耳机发烧友&#xff0c;我最近注意到数码圈特别是蓝牙耳机圈中&#xff0c;有一种耳机特别火&#xff0c;叫开放式耳机&#xff0c;这类耳机的佩戴舒适度是非常高的&#xff0c;这也激起了我对这类耳机的兴趣&#xff0c;因此…

感知笔记4:YOLO 3D 物体定位

如何在 ROS 中使用 YOLO 如何在 2D 中检测人和大象如何在 3D 中检测人和大象 有许多可用的深度学习库。您可能听说过&#xff1a;Keras、TensorFlow 和 Darknet。 在这里我们将使用 Darknet&#xff0c;因为它实现了 YOLOv3&#xff0c;这是一个对象检测模型。它非常快&…

jdk版本更换以及遇到的问题略谈(以jdk1.8和jdk11为例)

目录 在我看来 遇到的问题 原因以及解决方法 方法一&#xff1a;禁止误改误删 方法二&#xff1a;bat文件驱动运行 方法三&#xff1a;cmd命令 方法四&#xff1a;修改注册表&#xff08;不推荐&#xff09; 最近在进行漏洞复现&#xff08;shiro550&#xff09;的时候&…