gpt4 book ai didi

typescript - 根据另一个属性值键入 Svelte 组件属性

转载 作者:行者123 更新时间:2023-12-05 06:03:54 26 4
gpt4 key购买 nike

在 svelte 组件中

<script lang="ts">
export let multiple: boolean = false;
export let value: string|string[];

// ...
</script>

<!-- ... -->

value 属性的类型应该是 string 如果 multiple == falsestring[] 否则.如何实现?

编辑: 这个想法是得到一个 Discriminated Union对组件的影响。

最佳答案

您需要将“值”的类型设为条件类型。为此,您应该声明一个函数,该函数将为您确定并返回类型。这可以像这样完成:

declare function f<T extends boolean>(x: T): T extends false ? string : string[];

然后你可以定义你的 props,'value' 的类型将设置为字符串,除非组件声明将 'multiple' 设置为 true,其中 'value' 的类型将变为 string[]。

export let multiple: boolean = false;
export let value = f(multiple);

关于typescript - 根据另一个属性值键入 Svelte 组件属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66526968/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com