1

我正在建立一个对话服务。对话框可以有一个控制器,与$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 内置变体?

4

1 回答 1

1

$componentController属于 ngMock 模块,因为它对测试很有用,但在生产中被认为是 hack。由于 ngMock 足够大并且不应该在生产中可用,因此应该粘贴它以使其可用。

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

由于MdDialogController属于第三方模块,不注册不导出,体积小,直接粘贴即可。

于 2017-11-28T14:20:52.420 回答