javascript - 在 Javascript 中清除窗口对象中的自定义变量

标签 javascript internet-explorer-7 global

这个棘手的问题让我挠了挠头好几天。

我正在从事一个项目,该项目涉及将一个已有 10 年历史的 Web 应用程序重新设计为单页应用程序。该应用程序很大 - 我们必须工作的时间非常紧迫,因此必须走一些捷径。

但总的来说,我对我们取得的进展印象深刻,因为我们必须克服一些有趣的技术障碍。

一个涉及清除所有自定义窗口变量。由于我们正在动态地重新加载应用程序的不同页面,因此我们需要清除所有自定义变量,以免发生冲突。我们所做的是首先加载应用程序的基本 Bootstrap 并将窗口对象的所有属性保存在一个数组中。

然后,在我们加载每个新页面之前,我们遍历窗口属性并清除所有不在我们保存的数组中的对象(将窗口状态恢复到页面加载之前)。

现在,除了 IE7 和 IE8(两者都需要支持)之外,这在我们测试过的所有浏览器中都可以正常工作。问题似乎是全局变量似乎并不总是在窗口对象上注册。

有没有人对这个问题有任何见解?知道如何解决这个 IE7 问题吗?

任何信息将不胜感激。

编辑: 在 Bootstrap 加载时,我们这样做:

for (i in window) {
   this.globalVars[i] = 1;
}

然后当我们加载一个新页面(通过 AJAX)时,我们会:

for (i in window) {
   if (!this.globalVars[i]){
       window[i] = undefined;
   }
}

最终解决方案:

最后,在有限的时间里,最简单的解决方法是简单地更改所有定义为 var x 的变量;到 var x = null;

不过,我找到了另一个解决方案。这里有一个小型图书馆,我将其用作替代解决方案的起点:http://www.thomasfrank.se/global_namespace.html

它并不完美(可能需要进行一些调整以使其更加稳定,例如在 AJAX 调用周围添加一个 try-catch block ,这样跨域脚本就不会崩溃)。它的工作方式是解析所有外部脚本文件和内部脚本,提取大量单词,然后可用于清除窗口对象的属性。

我们实际上经历了一些非常奇怪的事情——这个脚本没有正确地获取我们的很多变量……事实证明它使用 document.scripts 来获取页面上所有加载的脚本以便能够循环他们并解析他们。问题是 jQuery 不会以这种方式在页面上加载外部页面。它所做的只是根据我所知道的将代码传递给 exec 。因此,实际上没有向页面添加任何脚本标记。

解决此问题的方法是解析原始 AJAX 响应并存储对所有脚本标记的引用(以及我想提取的内联脚本),然后修改库以能够处理这些文件。这应该可行,但由于速度原因,所有这些处理过程都太可怕了——发现我们可以简单地对所有变量定义进行搜索和替换,并完成大部分工作,而无需为每个页面加载进行大量工作。很明显我们应该走哪条路。

最佳答案

查看此问题:JavaScript: List global variables in IE

In IE, it global variables aren't enumerable unless you explicitly define them as properties of the window object.

因此,如果您要像这样分配变量:

var number = 42; // not inside any function

当您遍历 window 时,它不会显示。您必须像这样定义所有全局变量:

window.number = 42; 

或者像这样:

this.number = 42; 

关于javascript - 在 Javascript 中清除窗口对象中的自定义变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11896128/

相关文章:

c++ - 在全局和局部范围内定义和分配指向函数的指针

javascript - 在javascript中将变量传递给子级?

javascript - 选择 DIV 中除 ID 之外的所有链接

javascript - 来自 Angular 的 Http Post 请求不起作用

javascript - Google Maps API v3 在没有 fitbounds 的情况下无法加载,缩放导致无限循环/stackoverflow

html - 从缓存渲染 CSS 时,IE7 回退到 IE6 标准模式

javascript - 在 Javascript 中提取方法

javascript - 是否可以读取 JavaScript 全局/内置对象方法(即 array.filter、.sort)的代码?

php - 使用 javascript 启用/禁用按钮的问题

javascript - jQuery 触发器在 IE 中不起作用。为什么?