我的理解是在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'

答案 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