Vue3 中 DefineComponent 组件的Type,怎么正确声明vue组件的类型 TypeScript

通过TS的ReturnType泛型,获取到defineComponent的返回值即可

ReturnType<typeof defineComponent>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue 3 ,推荐使用 `defineComponent` 方法来声明组件类型。使用 `defineComponent` 方法可以让 TypeScript 正确推断组件的 props、data、methods 等属性的类型。 以下是一个使用 TypeScript 声明 Vue 3 组件类型的示例: ```typescript import { defineComponent } from 'vue'; export default defineComponent({ name: 'MyComponent', props: { name: { type: String, required: true }, age: { type: Number, default: 18 } }, data() { return { count: 0 }; }, methods: { handleClick(event: MouseEvent) { // do something } }, computed: { doubleAge(): number { return this.age * 2; } }, template: ` <div> <p>Name: {{ name }}</p> <p>Age: {{ age }}</p> <p>Double Age: {{ doubleAge }}</p> <button @click="handleClick">Click</button> </div> ` }); ``` 上述代码,我们使用 `defineComponent` 方法定义了一个名为 `MyComponent` 的组件类型,它包含 `props`、`data`、`methods`、`computed` 和 `template` 五个属性。其,`props` 属性是一个对象,包含 `name` 和 `age` 两个属性;`data` 属性是一个函数,返回一个包含 `count` 属性的对象;`methods` 属性是一个对象,包含一个名为 `handleClick` 的方法,它的参数是一个 MouseEvent 类型的事件对象;`computed` 属性是一个对象,包含一个名为 `doubleAge` 的计算属性,它返回的值是 `age` 的两倍;`template` 属性是一个模板字符串,用于渲染组件的内容。 使用 `defineComponent` 方法声明组件类型时,需要先导入 `defineComponent` 方法,并使用它来定义一个包含组件属性的对象。在组件,可以使用 `this` 访问组件实例,并根据需要调用 props、data、methods、computed 等属性。在模板,可以使用插值语法和指令语法来渲染数据和绑定事件。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值