如何解决错误重试策略和函数参数绑定
我想让我的 swr 状态突变能够抵御网络错误并支持某种重试功能。
基本上我所做的是在我的 useSWR 驱动的反应钩子中:
const setFavourite = useCallback((objectId) => {
const url = `/favs/${objectId}`
const newData = [objectId,...data]
return mutate(newData,false)
.then(() => request("POST",url))
.then(() => mutate())
.catch((error) => {
mutate(data,false).catch(() => {})
const userError = new Error("Could not add favourite")
userError.retry = () => setFavourite(objectId)
})
},[data,mutate,request])
我生成了一个带有 retry
函数的新 Error 对象,UI 代码可以使用该函数来显示 Toast 以便稍后(在用户交互时)重试操作。
我想知道在调用 retry()
时 setFavourite 的依赖项是否仍然有效。我想不会,因为它们依赖于 data
,如果这发生变化,那么 setFavourite
也会重新生成。
以前有人实现过这种重试吗?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。