Dostęp do numeru linii w V8 JavaScript (Chrome & Node.js)

Programiści JavaScript, którzy spędzili czas w językach takich jak C, często nie mają możliwości korzystania z pewnych typów introspekcji, takich jak rejestrowanie numerów linii, i z jakiej metody została wywołana bieżąca metoda. Cóż, jeśli używasz V8 (Chrome, Node.js) można zastosować następujące.

Author: james_womack, 2012-07-09

1 answers

Object.defineProperty(global, '__stack', {
  get: function(){
    var orig = Error.prepareStackTrace;
    Error.prepareStackTrace = function(_, stack){ return stack; };
    var err = new Error;
    Error.captureStackTrace(err, arguments.callee);
    var stack = err.stack;
    Error.prepareStackTrace = orig;
    return stack;
  }
});

Object.defineProperty(global, '__line', {
  get: function(){
    return __stack[1].getLineNumber();
  }
});

console.log(__line);

Powyższe zapisze 19.

W połączeniu z arguments.callee.caller możesz zbliżyć się do rodzaju użytecznego logowania, jakie uzyskasz w C za pomocą makr.

 81
Author: james_womack,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2012-07-08 20:35:35