-1

是否可以在父函数的范围内定义一个函数,并在返回之前将通过父函数传递的参数绑定为其范围?

这是一个例子:

var myObject = {
    foo: "bar"
};

var myFunction = (function() {
    return function() {
        return this.foo;
    };
}).call(myObject);

myFunction.call(myObject); // I'd like to bind myObject as this does ...

myFunction(); // ... but I'd like to do it before invoking it, without .call() or .apply()

或者另一个复杂的例子,它描述了我正在尝试做的事情:

var createMyCopy = function(original, self) {
    var copy;

    eval("copy=" + original.toString());

    console.log(copy()); // returns undefined
};

(function() {
    var self = "Hello world",
        myFunction = function() {
            return self;
        };

    console.log(myFunction()); // returns "Hello world"

    createMyCopy(myFunction);
})();

我正在尝试创建一个函数的副本,这样我就可以在不更改原始函数的情况下对其进行更改,但我也希望在副本中包含原始函数中定义的变量......

4

3 回答 3

1

你的意思是这样吗?

var myObject = {
    foo: "bar"
};

var myFunction = (function() {
    var self = this;
    return function() {
        return self.foo;
    };
}).call(myObject);

我认为您在问题中混淆了范围和上下文。

于 2012-04-27T20:26:36.553 回答
1

你的意思是:

var myFunction = (function(obj) {
    return function() {
        return obj.foo;
    };
})(myObject);

立即调用的函数表达式被传递myObject并返回一个新函数,其中该参数被绑定为变量obj

于 2012-04-27T20:27:58.900 回答
0

我不确定你的意思,但你可以这样做:

var myObject = {
    foo: "bar"
};
function myFunction() {
    return this.foo;
}
console.log(myFunction.apply(myObject)); // bar

的第一个参数apply是(即指的是context什么)。this的第二个参数apply是一个参数数组(但我在这里省略了,因为没有参数)。

于 2012-04-27T20:22:54.020 回答