Vue 插槽(2)

        在上一篇中初步介绍了 Vue插槽,这一篇讲一下作用域插槽。

一、使用场景

        作用域插槽允许父组件访问子组件内部的数据,并基于这些数据来渲染插槽的内容。作用域插槽使得组件之间的数据传递更加灵活和动态。

       在子组件中定义:

<template>  
  <div>  
    <slot :user="user"></slot>  
  </div>  
</template>  
  
<script>  
export default {  
  data() {  
    return {  
      user: {  
        name: 'John Doe',  
        age: 30  
      }  
    }  
  }  
}  
</script>

        在父组件中使用:

        通过 v-slot:插槽名 = "随便定义一个变量接收数据"  或  #插槽名="随便定义一个变量接收数据",默认插槽使用 default 作为插槽名。

<template>  
  <ChildComponent>  
    <template v-slot:default="slotProps">  
      <p>姓名: {{ slotProps.user.name }}</p>  
      <p>年龄: {{ slotProps.user.age }}</p>  
    </template>  

        //或

     <template #default="slotProps">  
      <p>姓名: {{ slotProps.user.name }}</p>  
      <p>年龄: {{ slotProps.user.age }}</p>  
    </template>  
  </ChildComponent>  
</template>

二、举例

子组件内插槽绑定变量

父组件内使用:

因为子组件内我们定义了 变量名 row 来传递数据,他是一个传递了item中的所有信息的对象,所以我们在父组件内 自定义一个 obj 来接收这个 row,使用数据时 obj.row.属性名。

插槽内插入的元素 他的样式和事件都定义在父组件内。

  • 18
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值