在生产中使用$ componentController?

时间:2017-11-28 13:30:46

标签: angularjs angular1.6

我正在构建一个对话服务。一个对话框可以有一个控制器,非常类似于 $ mdDialog ,如下所示:

myDialogService.show({
  templateUrl: `<div ng-click="$ctrl.log()">Hello dialog</div>`,
  controller: function() {
    this.log = function() {
      console.log("logged from myDialogController");
    }
  }
});

效果很好。我以这种方式调用控制器:

locals.$scope = scope;
const invokeController = $controller(options.controller, locals, true);

const controller = invokeController();
if (options.controllerAs) {
  scope[options.controllerAs] = controller;
} else {
  const controllerAs = "$ctrl";
  scope[controllerAs] = controller;
}

在angular-mock中是 $ componentController 服务,它可以调用组件控制器。使用我的代码,我只能调用已注册的控制器或给定控制器功能。这不是很有用,因为我只注册了组件,而不是单个控制器。

我的问题

是否有可能/建议在生产中使用 $ componentController ?或者我有监督的变体中是否有任何AngularJS版本?

1 个答案:

答案 0 :(得分:1)

$componentController属于ngMock模块,因为它对测试很有用,但在生产中被视为黑客攻击。由于ngMock足够大并且不应该在生产中使用,因此应该粘贴它以便可用。

解决此问题的正确方法是将注册的控制器重新用作组件控制器,或者使用JS模块导入/导出控制器函数/类。

由于MdDialogController属于第三方模块,因此不会注册或导出且很小,只需粘贴即可。