解决ie11 SCRIPT5011:不能执行已释放Script的代码问题
依照我遇到的问题为例:
(我的页面结构为:父页面中嵌套有iframe子页面)
1、造成这种情况的原因是:父页面初始化声明变量a为数组(数组对象是引用类型,赋值传递的是地址),创建iframe子页面后给父页面变量a赋值,赋值后销毁iframe子页面,再次调用变量a的时候就会抛出异常‘SCRIPT5011:不能执行已释放Script的代码'。
//父页面中
var a = [];
//iframe子页面中
$.each(arr,function (i,v) {
parent.a.push(v);
});
//iframe 子页面销毁后 再次调用a 会报错
2、解决办法:我们将父页面中的变量a定义为字符串(字符串是值类型,赋值传递的是值),子页面iframe中给父页面变量a赋值也为字符串,销毁iframe后,调用变量a时再解析成数组对象。
//父页面中
var a = '';
//iframe子页面中
var aa = []
$.each(arr,function (i,v) {
aa.push(v);
});
a = aa.join(',');
//iframe 子页面销毁后 再次调用a.split(',') 就没问题了
总结
以上所述是小编给大家介绍的解决ie11 SCRIPT5011:不能执行已释放Script的代码问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
相关文章
[js高手之路]设计模式系列课程-发布者,订阅者重构购物车的实例
下面小编就为大家带来一篇[js高手之路]设计模式系列课程-发布者,订阅者重构购物车的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-08-08
JavaScript 中 this 关键字的作用及改变其上下文的方法
这篇文章主要介绍了JavaScript 中 this 关键字的作用和如何改变其上下文,通过使用 call, apply, bind 方法,可以改变函数中的 this 指向,从而在不同的上下文中使用同一个函数,需要的朋友可以参考下2023-01-01


最新评论