我有很多东西想写。我想写我和策划哪些不可说的密码,但是考虑到公司的策划小姐姐可能暗中的关注着我;我也想写我和项目经理的情感纠葛,但是又害怕一个不留神被他看到“怀恨在心”;我甚至都想写和经理打游击的故事,但是考虑到我根基太浅 怕一不留神 被一脚踹出门去。事到如今,只好扒一扒我写前端项目的时候做的一件蠢事儿(Android项目犯蠢的事儿太多了),目的呢?只希望诸位读者朋友引以为鉴,千万不要犯我这样的低级错误。
一、 事件起源
事件的起因呢?是年初的时候在写前端的一个直播项目的时候。页面存在有很多很多的数据展示,在页面初始化的时候,会将很多的页面数据都初始化进去。
请求数据的代码差不多就是这样(如果对我封装http的代码有兴趣的朋友,可以期待我接下来的文章哦):
this.$okhttp(apis.rosterApi.getstate,
{lessonid: this.mylessonid}
).then(res => {
// dosomething...
}).catch(res => {
this.$message.error(res)
})
然后数据既然得到了,但是数据并不是单个组件在用,而是所有需要这份数据的组件共同需要需要,我一反应是使用全局事件,但是考虑到全局时间的穿透性和不可把控性,我还是放弃了,转向vuex。
// action 逻辑
saveTableData ({ commit }, tabledata) {
commit(types.REFRESH_TABLE_DATAS, tabledata)
}
// mutations 逻辑
[types.REFRESH_TABLE_DATAS](state, tabledata) {
state.tableData = tabledata
window.localStorage.setItem('tableData', JSON.stringify(state.tableData))
}
// 每次初始化vuex的时候
state.tableData = JSON.parse(window.localStorage.getItem('tableData'))
//使用:
this.$store.dispatch('saveTableData', res)
基本的代码都贴在这里了,谈到为什么要这么做呢?
- 之前有一套需求是这么做的,具体是什么我忘记了。
- 为了减少http请求,因为这个接口的数据量还是有点大的(Android的缓存思想)。
二、 问题出现了
由于项目匆匆忙忙的上线,我在本地也没有经过很长时间的推算就直接上去了。
第一周开直播的人数比较少,基本就是寥寥几个人,低空掠过~~
第二周同一时段的人开直播的小姐姐们多了起来,问题就出现了zzz
如果两个直播同时都打开的情况下,当用户切换直播间的时候 依然播放的是上一个直播间的流地址。刷新之后,播放器恢复正常,播放新流地址。
三、 排查问题
因为自己比较自信,我第一反应就是可能存在缓存没清理的关系。我首先去videojs官网去查询释放资源的接口,我发现官方有一个dispose
的接口专门用来释放资源。于是我就添了一行代码:
beforeDestroy(){
if(this.player){
this.player.dispose();
}
},
然后刷新了一下浏览器,发现恢复正常了。然后我就开始怀疑起了videojs这个插件。作为一个比较有心得的程序员这点傲气还是得有的吧。
首先我在网络请求返回值那里打印了一下–咦,新地址呀!看吧,肯定不是我写的后台的锅
然后转到videojs的播放器组件上面打印了一番—看吧,果然,我前端写的如此完美,肯定没问题
最后,我下定决心,一定是人家videojs的问题。突然莫名的兴奋,项目经理来问我这个问题,我也回复他说是人家videojs的问题,我一遍看着源码 一遍撸着袖子准备给github上面提issue。
就这样,很多人都在我理直气壮的话语中刷新着。过了一段时间,有一天广东这边来了台风 公司的网速不知道是不是太阳黑子加上所谓的龙卷风的淫威之下 趋于平缓(简直是慢的可怕)。然后加上公司来了几个比较有名的教师,我正好有另外的bug在调试,需要不断的进出直播间。
然后问题就出现了:我发现上一个直播间的数据在新直播间一闪而过(当时为了调试另一个问题,把loadding去掉了),我突然就想起了什么。
讲师在后台打开直播间的时候才会去申请流地址的,所以未打开直播间的时候 切换是没有问题的,当我打开直播间之后,原来是我每次都把上一次的数据保存到localStorage
里面,等到下次再进入直播间的时候首先是使用上一次保存的流地址,然后就会呈现出那种状况,当页面刷新的时候 就会再次使用前一次的流地址就会是正常的。
修改代码很简单:
- 分离出需要缓存的数据,用另一个字段进行存储
- 去掉
mutations 逻辑
和初始化的时候中的缓存代码即可
// window.localStorage.setItem('tableData', JSON.stringify(state.tableData))
// state.tableData = JSON.parse(window.localStorage.getItem('tableData'))
四: 说在最后
其实这着实是一件很小的事情,但是着实让我羞愧了一大把。作为一个比较严谨的程序人,我们不仅要会学习,还要对自己的代码有严格的把关。有的时候,问题虽然很小 但是映射出很多大的智慧。对自己写的代码自信是一件好事儿,但是盲目自信却能让别人对你的评价、整个团队的评价下一个档次。俗话说的好智者千虑、必有一失
、人非圣贤、孰能无过
,总之对于自己产出的代码 还是要小心的求证,力求完美。