# JavaScript
bfcache处理
最近业务上遇到个问题:
项目里有两个app,当页面初始化的时候会跑一段代码codeA将url中的一些参数存储到WebStorage中。
当从appA跳转到appB,然后使用浏览器自带的返回按钮返回appA时,发现WebStorage中的参数还是appB的参数,也就是appA的初始化时的代码codeA没有跑。
查询过后发现是触发了浏览器的bfcache机制。
页面卸载时向后端发送接口
工作中遇到一个需求,需要在用户关闭或者刷新页面时向后端发送该用户的身份信息。
浏览器页面卸载时会触发beforeunload和unload事件,由于unload限制比较多,因此这里选择了beforeunload。
问题:常用的异步ajax请求在unload/beforeunload事件内是不可靠的,浏览器可能会无视异步请求从而导致后端收不到。可以使用下述方法。
JS 垃圾回收机制
当我们创建对象时,js 会在内存空间开辟地址来存放这个对象的内容。随着软件的运行,创建的对象会越来越多,而当新创建的对象不断添加,不再被使用的老对象却没有被及时清理时,内存占用就会越来越多,造成程序的运行缓慢直到崩溃。这个过程就称为内存泄漏(Memory Leak) 。
强引用,弱引用
此概念与JS垃圾回收机制紧密相关:JS垃圾回收机制文档传送门