微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

检查后,打字稿对象可能是“未定义”的

如何解决检查后,打字稿对象可能是“未定义”的

快速问题-为什么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应用,也使用immerreact-beautiful-dnd

解决方法

我无法评论Alexsey L.所说的内容,但更快速的解决方法是使用!当您知道将要定义的内容时。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。