vue3 setup的两个参数

第一个参数props

props:值为对象,包含:组件外部传递过来,且组件内部声明接收了的属性。

<template >
  {{meg}}
  <B></B>
</template>
<script>
import B from "../components/B.vue";
// 引入自定义hooks
export default {
  props:['meg',"mei"],
  componments:{
    B
  },
  setup(props) {
    console.log(props);
  },
};
</script>

<style>
</style>

在这里插入图片描述

在这里插入图片描述

第二个参数context

context的attrs

保存当父组件传过来值时没有被props接收的值

<template >
  {{meg}}
  <B></B>
</template>
<script>
import B from "../components/B.vue";
// 引入自定义hooks
export default {
  props:['meg'],
  componments:{
    B
  },
  setup(props,context) {
    console.log(props);
    console.log("context");
    console.log(context);
  },
};
</script>

<style>
</style>

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
这样就取到值了

context的emit

子组件

<template >
  {{meg}}
  <button @click="test">点我给父组件传值</button>
</template>
<script>
// 引入自定义hooks
export default {
  props:['meg',"mei"],
  componments:{
  },
  emits:['a_emit'],
  setup({},context) {
    // console.log(props);
    // console.log("context");
    console.log(context);
   function test(){
     context.emit("a_emit","holle world")
   }
   
    return{
      test
    }
  },
};
</script>

<style>
</style>

父组件

<template>
  <div>
    <A  meg="你好" mei="大家" @a_emit="app_res"></A>
    {{clida_mess}}
  </div>
</template>

<script>
import A from"./components/A.vue"
import {ref} from "vue"
export default {
components:{
  A,
},
setup(){
  let clida_mess=ref("")
   function app_res(value){
     console.log("已经接收子组件A的数据,数据是"+value);
     clida_mess.value=value
   }
  return{
    app_res,
    clida_mess
  }
}
}
</script>

<style>

</style>

在vue3中每次定义emit时需要定义emit[ ]不然会发出警告
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

context的slot

当组件存在插槽时会在子组件中输出
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

万事胜意sy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值