
在做axios的封装时遇到的,真的是天坑这里被折磨惨了!这个报错是JSON解析失败,但我一直没有发现这个到底在哪里报错。最后一个断点一个断点找过去才发现这个天坑!
getCache(key: string) {
const value = window.localStorage.getItem(key);
if (value) {
return JSON.parse(value);
}
}
这个代码是我用来获取本地存储的token的,这乍一眼看是不是没有问题,我做梦也想不到是这里解析JSON出错了!

这里getItenm()的返回类型是string或null,最要命的就是这个undefined这返回的也是个字符串类型,绝了!JSON是解析不了undefined字符串的,
解析就会报错!还有虽然你可以将"undefined"转成JSON后再将它转回来,但你直接解析’undefined‘是不行的如下图

JavaScript博大精深啊~
最后初步先这样解决总感觉怪怪的,不得已啊
getCache(key: string) {
const value = window.localStorage.getItem(key);
if (value && value !== 'undefined') {
return JSON.parse(value);
}
}
博主在进行axios封装时遇到了JSON解析失败的问题,经过详细排查,发现问题是由于localStorage.getItem可能返回'undefined'字符串,而JSON.parse无法解析此值导致的异常。解决方案是在解析前检查value是否为'undefined'。这个小细节展示了JavaScript的微妙之处,提醒开发者在处理类似情况时要格外小心。
1万+

被折叠的 条评论
为什么被折叠?



