• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

vue3组件传值 defineProphotoshop 、defineEmits

武飞扬头像
大白o
帮助1

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'])

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgggjib
系列文章
更多 icon
同类精品
更多 icon
继续加载