我LocalStorage犯了两个小错误,差点导致项目大崩溃!

更新日期: 2022-06-16阅读: 1.8k标签: 错误

背景

这次分享我在项目中关于localStorage犯的两个小错误,由于我所做的功能点,被应用到了项目的核心模块中,所以这两个小错误,差点导致了整个项目上线后崩掉,现在想想都可怕~

真的,有些错误虽小,但是一定要杜绝啊~


一错:LocalStorage变量废弃

第一版

事情是这样的,我有一个需求,需要将一个url存进LocalStorage中

const  BASE_URL  =  'baseUrl'

// 存时
const setUrlStorage = (url: string) => {
Storage.set(BASE_URL, url)
}

// 取时
const getUrlStorage = () => {
return Storage.get(BASE_URL)
}

// 使用时
const baseUrl = getUrlStorage() ??
'http://api.com'

并且这个代码上线了,用户也使用了这段代码的功能。。

第二版

后来,觉得直接存不太好,得加个时间戳,让这个url具有时效性,这时候我将代码改成了

const  BASE_URL  =  'baseUrl'
// 失效时间
const TIME_OUT = 60 * 60 * 1000
// 存时
const setUrlStorage = (url: string) => {
Storage.set(BASE_URL, JSON.stringfy({
url,
// 添加时间
time: Date.now()
}))
}

// 取时
const getUrlStorage = () => {
const baseUrlObj =
Storage.get(BASE_URL)
const { url, time } =
JSON.parse(baseUrlObj)
// 判断是否失效
if (Date.now() - time >= TIME_OUT) {
return null
} else {
return url
}
}

// 使用时
const baseUrl = getUrlStorage() ??
'http://api.com'

问题来了

由于之前上线了第一版了,所以有的用户已经将url存在了LocalStorage中了,这时候存储中是

baseUrl  ->  'http://linsanxin.api.com'

但是后来我改成了第二版并且上线了,这个时候用户使用第二版的代码去取第一版中的存储,会导致报错

//  取时
const getUrlStorage = () => {
const baseUrlObj =
Storage.get(BASE_URL)
// 这里直接报错,取得是第一版的字符串
// JSON.stringfy + 字符串 直接报错
const { url, time } =
JSON.stringfy(baseUrlObj)
// ...coding
}

// 使用时
const baseUrl = getUrlStorage() ??
'http://api.com'

改正:变量废弃

那么应该怎么改正呢?大家要注意一个点:

当LocalStorage中某个缓存,它的数据格式改变了,那么一定要废弃他的key,换一个新的

所以正确改正方法是,将baseUrl这个变量废弃了,换个新的

//  废弃  const  BASE_URL  =  'baseUrl'
const BASE_URL = 'baseUrlV2'


二错:JSON.parse无错误处理

由上一个错误,可以发现,在JSON.parse时进行错误处理,是非常重要的

注意:JSON.parse不止用在取LocalStorage时,还有其他很多使用场景

所以,每次JSON.parse时要做好错误的兜底处理,防止由于错误导致后面代码执行不下去

//  取时
const getUrlStorage = () => {
try {
const baseUrlObj =
Storage.get(BASE_URL)
const { url, time } =
JSON.stringfy(baseUrlObj)
return url
} catch(e) {
return null
}
}
来源:前端之神,作者:林三心


链接: https://fly63.com/article/detial/11749

解决Cannot read property range of null 错误

vue工程npm run serve/start/dev启动时,node_modules文件报:Cannot read property range of null 错误,该问题是babel-eslint版本更新问题导致的;

HTTP 400 错误 - 请求无效 (Bad request)

在ajax请求后台数据时有时会报 HTTP 400 错误 - 请求无效 (Bad request);出现这个请求无效报错说明请求没有进入到后台服务里;原因:前端提交数据的字段名称或者是字段类型和后台的实体类不一致

js异步错误捕获

我们都知道 try catch 无法捕获 setTimeout 异步任务中的错误,那其中的原因是什么。以及异步代码在 js 中是特别常见的,我们该怎么做才比较?

不能执行已释放Script的代码

父页面初始化声明变量a为数组(数组对象是引用类型,赋值传递的是地址),创建iframe子页面后给父页面变量a赋值,赋值后销毁iframe子页面,再次调用变量a的时候就会抛出异常‘SCRIPT5011:不能执行已释放Script的代码’。

JS错误处理:前端JS/Vue/React/Iframe/跨域/Node

js错误的实质,也是发出一个事件,处理他,error实例对象message:错误提示信息,name:错误名称(非标准属性)宿主环境赋予

nodejs提示 cross-device link not permitted, rename 错误解决方法

文件上传的功能时候,调用fs.renameSync方法错误,这个提示是跨区重命名文件出现的权限问题。先从源文件拷贝到另外分区的目标文件,然后再unlink,就可以了。

Js中使用innerHTML的缺点是什么?

如果在JavaScript中使用innerHTML,缺点是:内容随处可见;不能像“追加到innerHTML”一样使用;innerHTML不提供验证,因此我们可能会在文档中插入有效的和破坏性的HTML并将其中断

Web前端开发,必须规避的8个错误点!

现在,有越来越多所谓的“教程”来帮助我们提高网站的易用性。我们收集了一些在Web开发中容易出错和被忽略的小问题,并且提供了参考的解决方案,以便于帮助Web开发者更好的完善网站。

web前端错误监控

为什么要做前端错误监控?1. 为了保证产品的质量2. 有些问题只存在于线上特定的环境3. 后端错误有监控,前端错误没有监控,前端错误分为两类: 即时运行错误和资源加载错误

自定义错误及扩展错误

当我们在进行开发的时候,通常需要属于我们自己的错误类来反映任务中可能出现的特殊情况。对于网络操作错误,我们需要 HttpError,对于数据库操作错误,我们需要 DbError,对于搜索操作错误,我们需要 NotFoundError,等等

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!