如何解决检查后,打字稿对象可能是“未定义”的
快速问题-为什么Typescript仍然认为它将是未定义的?
在我的应用程序中添加以下代码后,在行draft.splice(result.destination.index,draggedItem);
上出现Typescript错误,提示result.destination
对象可能未定义。键入以下内容时,部分正确:DragUpdate.destination?: DraggableLocation | undefined
。但是,我在此函数的开头进行了检查,因此在给定的行将永远不会是undefined
。
const onDragEnd = useCallback((result: DropResult) => {
// do nothing if no destination
if (!result.destination) return;
setState((prevstate: IOrderCard[]) =>
produce(prevstate,draft => {
const draggedItem = draft[result.source.index];
draft.splice(result.source.index,1);
draft.splice(result.destination.index,draggedItem);
return draft;
})
);
},[]);
这是带有钩子的React应用,也使用immer
和react-beautiful-dnd
。
解决方法
我无法评论Alexsey L.所说的内容,但更快速的解决方法是使用!当您知道将要定义的内容时。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。