> 上周8号晚上上线发现一个问题,部分用户无法打开网站,我们这边的机器又都可以。查了半天是因为 localStorage 引起的,以前的开发人员写代码时也不够严谨,真是头疼。
### 问题现象
当时我们都可以正常打开页面,业务部门却说无法打开,让其打开控制台后,发现有报错。

### 分析原因
由于我们无法复现客户的现象,所以联系业务部门上 zoom 投屏给我们看,后来定位到是获取语言时报的错。

语言是存储在 localStorage 里的,然后让用户操作查看了用户的 localStorage,如下:

用户的电脑上存的是 EN-US
然后我们查看我们自己的电脑,可以看到 lang 字段是按照 json 格式存储的

推测用户是在别的网站登录过,别的网站用来控制语言的字段正好和我们网站是同一个,取名都为 lang ,所以在获取时获取不到。而事实也是如此,会员网站与我们营销网站用的都是 lang 字段。
最坑爹的是,以前的开发人员没有进行判空,如果获取不到,整个js就直接报错了,导致页面无法正常展示。
所以我们加了个判空的情况,获取不到时就默认给一个英文。
**默认给英文之后,又发现用户只是一部分页面可以打开,有些还是无法打开。**
继续分析后,发现程序中引用的 localStorage.js 有点问题,在存储 localStorage 时,会先将其删除,而删除是删除json格式的,用户存储的是 EN-US,非 json 格式,删除失败,直接报错了。代码中虽然用了 try catch, 但是并没有作特殊处理,所以还是没有设置语言成功。

查了半天终于查到原因了,那时也到了半夜,真心累。
### 解决办法
因为 localStorage.js 是公共的 js,担心大改会引发别的问题,最后决定是对 lang 字段进行特殊处理,如果删除报错,还是在 catch 里面继续进行往后的操作,插入新的 localStorage。

至此,问题解决。

记录一下因 localStorage 引发的故障