gpt4 book ai didi

javascript - 有关 Javascript 范围的帮助

转载 作者:行者123 更新时间:2023-11-28 02:49:42 24 4
gpt4 key购买 nike

这个例子是我的代码的简化版本。我仍在尝试掌握编写 javascript 的新方式(与 10 年前的方式相反),所以感谢您的耐心等待。我需要访问 globalVal 的值,但我遇到了麻烦。该值是从作为另一个方法的参数调用的函数中获取的。这个例子可能更容易理解。只需能够从 DOM 中的任何位置访问 globalvar 即可。这可能吗?谢谢

<html>
<head>
<script type="text/javascript">
var globalvar;

function initialize() {
var someVariable = 5;
doSomething(someVariable, getTheVar);
}

function doSomething(someVariable, expectGlobalVar) {
//alert(someVariable);
alert(expectGlobalVar);
}

function getTheVar() {
globalVar = "test";
return globalVar;

}
</script>
<title></title>
</head>
<body onload="initialize()">
This is a test
</body>
</html>

最佳答案

基本上没问题,如果您按照自己的方式声明它,则可以从页面中任何位置运行的任何脚本直接访问globalVar

具体来说:在页面级范围(即在任何函数之外)使用var x;会在window对象上声明一个属性(它有一个特殊功能,即无法删除,但这不是此处很重要)。

var foo = 2;
window.foo = 2; // Basically the same other than the delete thing we're not worrying about here

所以:

var foo = 2;
alert(foo); // alerts "2"
alert(window.foo); // also alerts "2"
window.bar = 4;
alert(window.bar); // alerts "4"
alert(bar); // also alerts "4"

当然,这仅适用于任何功能之外的顶层。 在函数内部,您声明了函数的局部内容。 (本质上,它实际上比这更有趣。)

但是既然您已经询问了范围,那么您定义的所有其他内容(initializegetTheVardoSomething)也是全局变量,这一点毫无意义。一般来说,您希望避免将任何可以避免放置的内容放入全局命名空间中。

因此,我主张始终使用“范围界定函数”:

(function() {
// your code here
})();

...并明确地仅导出您真正需要全局的内容(通过将它们分配给window上的属性)。

就您而言,您说过您需要globalVar并且您还使用了initialize(尽管还有其他方法可以完成您在initialize中所做的事情),所以您可以这样做:

(function() {
var globalvar;

// Exports
window.globalVar = globalVar;
window.initialize = initialize;

// Implementation

function initialize() {
var someVariable = 5;
doSomething(someVariable, getTheVar);
}

function doSomething(someVariable, expectGlobalVar) {
//alert(someVariable);
alert(expectGlobalVar);
}

function getTheVar() {
globalVar = "test";
return globalVar;
}
})();

但你可以更进一步。由于在initialize元素的load事件发生之前您不会调用body,因此您可以避免发布initialize。只需将您的脚本标记放在文档的末尾,就在结束</body>标记之前(如the YUI folks推荐),并在那里进行初始化:

<html>
<head>
<title>...</title>
</head>
<body>This is a test
<script type='text/javascript'>
(function() {
var globalvar;

// Initialization
initialize();

// Exports
window.globalVar = globalVar;

// Implementation
function initialize() {
var someVariable = 5;
doSomething(someVariable, getTheVar);
}

function doSomething(someVariable, expectGlobalVar) {
//alert(someVariable);
alert(expectGlobalVar);
}

function getTheVar() {
globalVar = "test";
return globalVar;
}
})();
</script>
</body>
</html>

此时 DOM 为fully loaded and ready to go

但是如果我们愿意,我们可以走得更远:如果我们愿意,我们可以在全局命名空间中什么都没有。如果您在initialize函数中连接所有处理程序,而不是使用onloadonclick和类似属性,则globalVar不需要是全局的,除了您的代码。 (您可以使用attachEvent[在 IE 上]、addEventListener[在基于标准的浏览器上]来连接处理程序,或者更好的是使用jQueryClosurePrototypeYUI等库”,或any of several others。)

关于javascript - 有关 Javascript 范围的帮助,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4059020/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com