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