之前一直都不曾注意到这一点,今天幸亏看了kuibono的文章,下面是kuibono给出的手动回收xmlhttprequest对象的代码片断:
每次jquery的ajax请求都会创建一个xmlhttprequest对象,理论上讲,长连接的请求是一个无限递归,请求数量是非常大的,但是由于每次请求都会建立一个新的xmlhttprequest,而且jquery不会自动回收资源,所以导致了内存溢出。
通过查看jquery api,发现jquery还有一个 complete对象,是请求完成后回调函数 (请求成功或失败之后均调用)。 同时有两个参数xmlhttprequest, textstatus。所以,我们只需要在请求完成后,将传回的xmlhttprequest对象手工回收即可,代码如下:
代码如下:
$.ajax({
url: "https://www.jb51.net",
data: { name: "xxxx" },
datatype: "xml",
success: function (data, textstatus) {
//do something...
},
complete: function (xhr, ts) { xhr = null }
});
如对本文有疑问, 点击进行留言回复!!
同事牛逼啊,写了个隐藏 bug,我排查了 3 天才解决问题!
【JavaScript笔记(一)】万丈高楼平地起 - 基本概念篇
轻松解决 org.apache.taglibs.standard.tlv.JstlCoreTLV 困惑
网友评论