这是一个棘手的问题,让我摸不着头脑好几天了。
我正在从事一个项目,该项目涉及采用一个已有十年历史的 Web 应用程序并将其重新设计为单页应用程序。该应用程序非常庞大——我们必须工作的时间非常紧迫,因此必须做出一些捷径。
然而,总的来说,我对我们所取得的进展印象深刻,因为我们必须克服一些有趣的技术障碍。
一项涉及清除所有自定义窗口变量。由于我们正在动态地重新加载应用程序的不同页面,因此我们需要清除所有自定义变量,以免发生冲突。我们首先要做的是加载应用程序的基本引导程序并将窗口对象的所有属性保存在一个数组中。
然后,在我们加载每个新页面之前,我们遍历窗口属性并清除所有不在我们保存的数组中的对象(将窗口状态恢复到加载页面之前)。
现在,这在我们测试过的所有浏览器中都可以正常工作,除了 IE7 和 IE8(两者都需要支持)。问题似乎是全局变量似乎并不总是在窗口对象上注册。
有人对这个问题有任何见解吗?知道如何解决这个 IE7 问题吗?
任何信息将不胜感激。
编辑:在引导加载时,我们这样做:
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 块,以便跨域脚本不会使其崩溃)。它的工作方式是解析所有外部脚本文件和内部脚本,提取大量单词,然后可以使用这些单词从窗口对象中清除属性。
我们实际上经历了一些非常奇怪的事情——这个脚本没有正确地获取我们的很多变量......原来它使用 document.scripts 来获取页面上所有加载的脚本,以便能够遍历它们并解析他们。问题是 jQuery 不会以这种方式在页面上加载外部页面。它所做的只是将我所知道的代码传递给 exec 。因此,实际上没有将脚本标签添加到页面中。
对此的解决方法是解析原始 AJAX 响应并存储对所有脚本标记的引用(以及,我想,提取内联脚本),然后修改库以能够处理这些文件。这应该可以工作,但是由于速度原因,所有这些处理都太可怕了——发现我们可以简单地对所有变量定义进行搜索和替换,并且完成大部分工作,而不需要为每个页面加载大量工作。很明显我们应该走哪条路。