はJS忍者の秘密から、少し例を次に示します。奇妙なJavaScript関数の挙動
function addMethod(obj, methodName, fn) {
const old = obj[methodName];
obj[methodName] = function() {
if (fn.length === arguments.length) {
return fn.apply(this, arguments);
} else if (typeof old === 'function') {
return old.apply(this, arguments);
}
};
}
let ninja = {};
addMethod(ninja, 'whatever', a => console.log(`one: ${a}`));
ninja.whatever(1);
addMethod(ninja, 'whatever', (a,b) => console.log(a, b));
ninja.whatever(2, 2);
addMethod(ninja, 'whatever', (a,b, c) => console.log(a, b, c));
ninja.whatever(3);
console.log(ninja);
console.dir(addMethod);
、なぜこの機能
a => console.log(`one: ${a}`)
として、この変数
const old = obj[methodName];
仕事で私は理解できません
このファンクションが必要であると思います。
(a,b) => console.log(a, b)
、ありがとう。そのような行動は私にとっては珍しいことです –