透传属性$attrs

透传属性$attrs

前言

  • 我们首先在父组件上面定义一些数据
vue 复制代码
<template>
  <div class="box">
    <h3>父组件</h3>
    <h4>姓名1:{{ name1 }}</h4>
    <h4>姓名2:{{ name2 }}</h4>
    <h4>姓名3:{{ name3 }}</h4>
    <h4>姓名4:{{ name4 }}</h4>
    <Child />
  </div>
</template>

<script setup lang="ts">
import Child from './Child.vue'
import { ref } from 'vue';
let name1 = ref('张三');
let name2 = ref('王五');
let name3 = ref('李四');
let name4 = ref('赵六');
</script>
  • 那我现在想把父组件的一个name传给子组件怎么做呢?用props最简单
vue 复制代码
    <Child :name1="name1" />
  • 子组件只要接受一下就行了
vue 复制代码
<template>
  <div class="box">
    <h3>子组件</h3>
    <h4>{{ name1 }}</h4>
    <GrandChild />
  </div>
</template>

<script setup lang="ts">
import GrandChild from './GrandChild.vue';
defineProps(['name1'])

</script>
  • 那我可不可以将四个name都传过去呢,答案是可以的
vue 复制代码
    <Child :name1="name1" :name2="name2" :name3="name3" :name4="name4" />
  • 那如果我子组件只接受一个,其他三个跑哪里去了呢?因为归根揭底我父组件确实传给你了,我们使用vue扩展找找看在哪里

**

**

  • 我们发现在子组件中声明过props的就会在props立马,没有声明的都会在attrs,那是不是我们直接使用这个也会将变量读出来,我们来试试
vue 复制代码
<template>
  <div class="box">
    <h3>子组件</h3>
    <h4>{{ name1 }}</h4>
    <h4>{{ $attrs }}</h4>
    <GrandChild />
  </div>
</template>

那如何传给孙组件呢?

  • 先来介绍一下概念

"透传"指的是将父组件传递的、但未被子组件声明为 props 的属性,直接传给子组件内部的某个元素。

  • 想传给孙组件,子组件什么都不需要做?只需要把$attrs通过props给孙组件就可以了
vue 复制代码
<template>
  <div class="box">
    <h3>子组件</h3>
    <GrandChild v-bind="$attrs" />
  </div>
</template>

<script setup lang="ts">
import GrandChild from './GrandChild.vue';
</script>
  • 然后孙组件只需要接受就可以了
vue 复制代码
<template>
  <div class="box">
    <h3>孙组件</h3>
    <h4>姓名1:{{ name1 }}</h4>
    <h4>姓名2:{{ name2 }}</h4>
    <h4>姓名3:{{ name3 }}</h4>
    <h4>姓名4:{{ name4 }}</h4>
  </div>
</template>

<script setup lang="ts">
defineProps(['name1', 'name2', 'name3', 'name4'])
</script>
相关推荐
希望永不加班11 小时前
SpringBoot 静态资源访问(图片/JS/CSS)配置详解
java·javascript·css·spring boot·后端
oh LAN11 小时前
RuoYi-Vue-master:Spring Boot 4.x (JDK 17+) (环境搭建)
java·vue.js·spring boot
m0_7381207211 小时前
渗透基础知识ctfshow——Web应用安全与防护(第一章)
服务器·前端·javascript·安全·web安全·网络安全
持续前行11 小时前
通过 npm 下载node_modules 某个依赖 ;例如 下载 @rollup/rollup-linux-arm64-gnu
前端·javascript·vue.js
Embrace92412 小时前
React Native + Realm 离线方案处理
javascript·react native·react.js·realm
chenyingjian12 小时前
鸿蒙|能力特性-统一文件预览
前端·harmonyos
毛骗导演12 小时前
OpenClaw 沙箱执行系统深度解析:一条 exec 命令背后的安全长城
前端·架构
天才聪12 小时前
鸿蒙开发vs前端开发1-父子组件传值
前端
卡尔特斯12 小时前
Android Studio 代理配置指南
android·前端·android studio
李剑一12 小时前
同样做缩略图,为什么别人又快又稳?踩过无数坑后,我总结出前端缩略图实战指南
前端·vue.js