开发者问题收集

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>

现在我们添加 otherPropvalidator

<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