我想获取一个查询(Prisma上的TRPC查询)的输出,并将其用作将来查询的依赖输入。
我遵循了React Query的相关文档,但遇到了类型错误,第一个的返回可能未定义(例如product is possibly 'undefined'
):
const { data: product } = api.product.getUnique.useQuery({ id: pid });
const options = api.option.getAll.useQuery(
{
product: product.productSize,
region: product.productRegion,
},
{ enabled: !!product }
);
enabled的包含是否还没有处理这个问题?如果没有,适应Typescript的正确方法是什么?
1条答案
按热度按时间rqqzpn5f1#
只要将
product
值转换为布尔值,返回任意 truthy 值(例如,如果product
将等于{}
,仍然会导致true
,这意味着product
不一定具有productSize
或productRegion
属性,我将首先将其更改为:{ enabled: !!product && product.productSize && product.productRegion }
如果这不能修复typescript错误,作为开发人员,您可以确定值确实存在,因此您可以在typescript中使用
as
关键字,告诉它您确定类型是您想要的类型:(在本例中,我假设值是字符串,但您可以将其更改为数字或任何它们的真实值)