下面的JavaScript代码演示了JavaScript (闭包)函数如何通过引用而不是通过值访问其封闭环境中的变量。
var sum; // global variable
function outer() {
var hundred_more = 100;
sum = function (a, b) {
return a + b + (++hundred_more);
};
sum2 = function (a, b) {
return a + b + (++hundred_more);
};
alert(hundred_more);
}
outer(); // define sum at the global scope and print 100
alert(sum(5, 10)); // 116
alert(sum(5, 10)); // 117
alert(sum2(5, 10)); // 118
alert(sum2(5, 10)); // 119
outer(); // redefine sum at the global scope and print 100
alert(sum(5, 10)); // 116
alert(sum(5, 10)); // 117
alert(sum2(5, 10)); // 118
alert(sum2(5, 10)); // 119PHP中的相同代码如下所示:
<?php
$sum = null; // global variable
$sum2 = null; // global variable
function outer() {
global $sum;
global $sum2;
$hundred_more = 100;
$sum = function ($a, $b) use (&$hundred_more) {
return $a + $b + (++$hundred_more);
};
$sum2 = function ($a, $b) use (&$hundred_more) {
return $a + $b + (++$hundred_more);
};
var_dump($hundred_more);
}
outer(); // define sum at the global scope and print 100
var_dump($sum(5, 10)); // 116
var_dump($sum(5, 10)); // 117
var_dump($sum2(5, 10)); // 118
var_dump($sum2(5, 10)); // 119
outer(); // redefine sum at the global scope and print 100
var_dump($sum(5, 10)); // 116
var_dump($sum(5, 10)); // 117
var_dump($sum2(5, 10)); // 118
var_dump($sum2(5, 10)); // 119为了在PHP中通过值而不是引用从封闭环境中传递变量,只需在use关键字之后省略变量前面的符号(&)。这将导致在定义函数时将值复制到函数的闭包作用域中,以便所有'var_dumps‘打印值116。是否有可能在JavaScript中以某种方式实现相同的构造(变量通过值而不是引用传递到内部闭包)?
谢谢。
发布于 2014-10-28 19:26:45
好吧,你可以为它再找个了结.
function outer() {
var hundred_more = 100;
sum = (function(hundred_more){
return function (a, b) {
return a + b + (++hundred_more);
};
})(hundred_more);
sum2 = (function(hundred_more){
return function (a, b) {
return a + b + (++hundred_more);
};
})(hundred_more);
alert(hundred_more);
}
outer(); // define sum at the global scope and print 100
alert(sum(5, 10)); // 116
alert(sum(5, 10)); // 117
alert(sum2(5, 10)); // 116
alert(sum2(5, 10)); // 117
outer(); // redefine sum at the global scope and print 100
alert(sum(5, 10)); // 116
alert(sum(5, 10)); // 117
alert(sum2(5, 10)); // 116
alert(sum2(5, 10)); // 117
它实际上不是通过引用传递的;它们只是引用相同的变量。通过创建一个新闭包,我们通过引用传递旧的闭包,并得到解耦的变量。
https://stackoverflow.com/questions/26616752
复制相似问题