vue3组件传值 defineProps 、defineEmits

Vue3 + TS组件传值(definePropsdefineEmits

script setup> 中必须使用 definePropsdefineEmits API 来声明 propsemits ,它们具备完整的类型推断并且在 <script setup> 中是直接可用的:

父组件

<template>
  <div>
    <Child
      :msg="'传递的值'"  // 传值
      @change="change"  // 调用子组件方法
    />
  </div>
</template>

<script setup lang="ts">
const change = (val: number) => {
  console.log(val)
}
</script>

子组件

// 1.接收父组件传值
const props = defineProps<{
  foo: string
  bar?: number
}>()

// 2.想要设置默认值,通过 withDefaults 编译器宏
interface Props {
  msg?: string
  labels?: string[]
}

const props = withDefaults(defineProps<Props>(), {
  msg: 'hello',
  labels: () => ['one', 'two']
})

console.log(props.msg)  // hello
// 抛出事件
const emit = defineEmits<{
  (e: 'change', id: number): void
  (e: 'update', value: string): void
}>()

const click = () => {
  emit('change', 1)  
  emit('update', 'abc')
}

// 非ts
const props = defineProps({
  foo: String
})

const emit = defineEmits(['change', 'delete'])
  • 12
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值