JavaScript 中的全局变量无法正常工作

Global variable in javascript not working properly

本文关键字:常工作 工作 全局变量 JavaScript      更新时间:2023-09-26

我有一个iframe问题(对我来说有点奇怪)。问题是我的文档中有一个 iframe,并且有几个函数在该 iframe 上运行不同的任务以及用于访问我们使用的 iframe 的内容:

$("iframe").contents();

所以我没有写这个长语句,而是使用了一个全局变量:

var i = $("iframe").contents();

但这效果不佳,例如

alert( i.find("someelement") );    

=> undefined

alert($("iframe").contents().find("someelement")    

=> [object]

这里有什么问题?

替换

var i = $("iframe").contents();

window.i = $("iframe").contents();

由于i的作用域小于 window, 用于在 JavaScript 中声明全局变量。

但还有一件事是,如果它来自不同的域,则无法修改iframe中的任何项目。希望这有帮助。

您可能在某处覆盖i,或者它不是全局的。为了确保它是全局的,请不要使用 var。相反,定义window.i = ...;并始终引用window.i 。这避免了与局部变量的混淆(鉴于i几乎总是用作迭代器变量,这种情况经常发生)。另外,如果您将i用于 iframe 以外的任何内容(例如前面提到的迭代器),请确保始终将其声明为本地。

您的 iframe 内容是否与插入它的页面位于同一域中?

更多: http://en.wikipedia.org/wiki/Same_origin_policy