在
angular-logger,我们试图增加$log,但是我们希望以角度的模块和组件的名义工作,而不会改变.为此,我们需要在运行时获取AngularJS上下文,即模块名称和控制器,服务或指令名称.
app.module("SampleModule"). controller("ControllerOne",function ($log) { $log.debug("I am ready!") }). controller("ControllerTwo",function ($log) { $log.debug("I am ready!") });
默认$log输出:
> I am ready! > I am ready!
如果我们可以在运行时获取模块和控制器名称,那么使用增强的$log我们可以获得更丰富的输出:
> SampleModule.ControllerOne: I am ready! > SampleModule.ControllerTwo: I am ready!
最好的选择是获得它,而不会更改控制器的代码.也许有办法得到一些关于收到$log依赖注入的实体的元信息?
有什么建议么?
在SO上有一个
similar question that I found,但解决方案只有在使用控制器作为语法时才有效.
// a simple route with controller as Syntax $routeProvider.when( '/myRoute',{ templateUrl: '/myRoute',controller: 'ControllerOne as vm' } ); // controller app.controller("ControllerOne",['$log',function ControllerOne($log) { var vm = this; $log.log(vm.constructor.name); }]);