0

さまざまな関数が呼び出されるたびに記録しています。という関数があります

record_activity( function_name );

追跡したいすべての関数の一番上にこれを書く必要はありません。現在、次の形式の関数が多数あります。

Object.Key.Func = function() { ... }

私はこれを書きましたが、うまくいくようですが、その意味についてはよくわかりません:

function sub ( variable, func ) {
    var temp_func = function ( args ) {
        record_activity( variable );
        return func.apply(this,arguments);
    }
    eval( variable + ' = ' + temp_func );
}

sub( 'Object.Key.Func', function (name) { alert('hi ' + name) } );
Object.Key.Func('test');

eval なしでこれを行う方法があれば、私はもっと幸せになるでしょう。

ありがとう

4

1 に答える 1

0

追跡したい関数ごとにラッパー関数を作成できると思います。次のコードがお役に立てば幸いです。

var counter = {};
// assume this is what record_activity has to do.
function record_activity (f, func_name, args) {
    counter[func_name] = counter[func_name]===undefined ? 1 : counter[func_name]+1;
}

// assume that you want to keep track of functional call obj.foo and obj.bar
var obj = {
    a: 3,
    foo: function () {
        console.log("foo");
    },
    bar: function (b) {
        console.log("bar", this.a, b);
    }
};



function create_func (f, func_name) {
    return function () {
        record_activity(f, func_name, arguments);
        f.apply(obj, arguments);
    };
}
for(var prop in obj) {
    if (typeof obj[prop] === 'function') {
        // create the wrapper func
        obj[prop] = create_func(obj[prop], prop);
    }
};

// test
for (var i = 0; i < 3; i++) {
    obj.foo();
};
for (var i = 0; i < 10; i++) {
    obj.bar(i);
};

console.log(counter);
于 2013-09-12T11:41:12.373 に答える