替换javascript中通过引用传递的函数

时间:2015-04-13 18:42:44

标签: javascript

我的理解是在javascript中,函数通过引用传递...在这种情况下,我试图用另一个函数替换一个函数。它不起作用。我确信我错过了一些简单的事情。但是什么?



var spit = {
	spittle: function (x) {
		console.log('i spittle at ' + x);
	}
}

replaceFunc = {
	replace: function (func) {
		func = console.log;
	}
}

replaceFunc.replace(spit.spittle);

spit.spittle('joe'); /// should be just 'joe' instead the spittle func is not replaced and it outputs 'i spittle at joe'




2 个答案:

答案 0 :(得分:2)

JavaScript中没有通过引用传递。一个选项是传递整个spit对象并进行修改。

var spit = {
    spittle: function (x) {
        console.log('i spittle at ' + x);
    }
}

var replaceFunc = {
    replaceSpittle: function (funcContainer) {       
        funcContainer.spittle = function() {
            console.log.apply(console, arguments);
        }
    }
}

replaceFunc.replaceSpittle(spit);

spit.spittle('joe');

答案 1 :(得分:1)

replaceFunc.replace(spit.spittle);spit.spittle中存储的函数传递给replaceFunc.replace中存储的函数,因此,一旦您进入替换函数,它就无法获取返回spittle的{​​{1}}属性,而不是直接将其引用为spit

一种解决方法是将要替换的属性的对象和名称都传递给函数。



spit.spittle