vue中v-bind=“$attrs“和v-on=“$listeners“的含义(记录)

**一、**加入自定义了组件B componentB; 在componentA中引用 B,并使用props接收了两个参数,比如:name、age, 在A中这样调用B

<componentB
  :name='_name'
  :age='age'
  :phone='phone'
  @study='study'
/>

**二、**如果componentB 又调用了组件C componentC,若componentC想获取从componentA中没有被componentB的props接收的参数,componentB的如下:

<template>
  <div v-bind="$attrs" v-on="$listeners"></div>
  <componentC />
</template>
<script>
export default {
   indeterminate: true,
   props: {
     name,
     age
   }
 }

**三、**在组件C中就可以这样调用(可以通过vm. a t t r s 获 取 祖 先 组 件 传 输 的 数 据 , 通 过 v m . attrs 获取祖先组件传输的数据, 通过vm. attrs,vm.listeners获取祖先节点的methods)

export default {
  mounted () {
    // 访问ComponentA传入的`phone`, ComponentB的props并未接收
    console.log(this.$attrs.phone)
    // 触发ComponentA绑定`study`事件, 并非ComponentB emit的
    this.$emit('study')
  }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值