Vue 3:带有 Validator 的 prop => TypeScript 错误,声称其他 prop 不存在
2021-06-24
3592
在 Vue (v3) 中,使用
validator
添加 prop 会导致 TypeScript 错误,声称另一个属性不存在。我创建了一个组件来说明这个问题:
这有效:
<template>
<div>{{myComputed}}</div>
</template>
<script lang="ts">
import { defineComponent, computed } from 'vue';
export default defineComponent({
name: 'MyComponent',
props: {
someProp: String
},
setup(props) {
return {
myComputed: computed(() => ('ABC_' + props.someProp + '_XYZ'))
};
}
});
</script>
现在我们添加
otherProp
和
validator
:
<template>
<div>{{myComputed}}</div>
</template>
<script lang="ts">
import { defineComponent, computed } from 'vue';
export default defineComponent({
name: 'MyComponent',
props: {
someProp: String,
otherProp: {
type: String,
default: '',
validator: (v) => (true) // <- Problem occurs when
// adding this line
}
},
setup(props) {
return {
myComputed: computed(() => ('ABC_' + props.someProp + '_XYZ'))
// Complains that `props.someProp` --^
// is not defined here
};
}
});
</script>
我们收到一条错误消息:
ERROR in src/components/MyComponent.vue:21:50
TS2339: Property 'someProp' does not exist on type 'Readonly<LooseRequired<Readonly<{ [x: number]: string; } & { length?: number | undefined; toString?: string | undefined; toLocaleString?: string | undefined; concat?: string[] | undefined; join?: string | undefined; ... 17 more ...; flat?: unknown[] | undefined; }> | Readonly<...>>>'.
19 | setup(props) {
20 | return {
> 21 | myComputed: computed(() => ('ABC_' + props.someProp + '_XYZ'))
| ^^^^^^^^
22 | // Complains that `props.someProp` --^
23 | // is not defined here
24 | };
在
setup
中使用
computed
对象而不是
computed
函数会产生类似的结果(然后抱怨
this.someProp
不存在,即使它在运行时存在)。
为什么会出现这个错误?我们怎么能预测到这种行为?
validator
是否仍受支持?
目前的解决方法:我放弃了
validator
。
2个回答
将类型添加到
validator
参数:
otherProp: {
type: String,
default: '',
validator: (v:string) => (true)
// ^-----------
}
Boussadjra Brahim
2021-06-24
如果这对你不起作用或者还不够,那么将你的 props 包装在如下的 defineProps 中可能会有所帮助:
props: defineProps({
otherProp: {
type: String,
default: '',
validator: (v) => (true)
}
}),
sinini
2022-12-20