记一次VUE3属性传递时复杂类型的报错问题

这篇博客介绍了如何在Vue中利用typescript的utility types来精确定义组件props的类型,例如将`list`属性定义为`MenuItem`类型的数组。通过`defineProps`和`Array as PropType<MenuItem[]>`,可以确保传入的数据符合接口MenuItem的结构,从而提高代码的类型安全性和可维护性。

直接上typescript代码:

interface MenuItem {
    name?: string,
    icon?: string,
    action?: string
}

const emit = defineEmits([]);
const props = defineProps({
    list: Array
});

想将 list 数组元素定义为MenuItem类型时,可使用:

const props = defineProps({
    list: Array as PropType<MenuItem[]>
});

参考:https://cn.vuejs.org/api/utility-types.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值