加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angularjs – 初始化非注入角度服务

发布时间:2020-12-17 17:14:15 所属栏目:安全 来源:网络整理
导读:我有一个角度服务,在其构造函数中侦听$rootscope上的事件. 此服务不会在应用程序中的任何位置注入,因此不会初始化. 要解决这个问题,我们只是注入它而不是在另一个服务中使用它,只是为了让它“新手”. 有没有办法初始化服务而不必将其注入其他服务/控制器/指
我有一个角度服务,在其构造函数中侦听$rootscope上的事件.

此服务不会在应用程序中的任何位置注入,因此不会初始化.
要解决这个问题,我们只是注入它而不是在另一个服务中使用它,只是为了让它“新手”.

有没有办法初始化服务而不必将其注入其他服务/控制器/指令?

解决方法

通常,Angular为您提供了module.run(fn)API来进行初始化. fn参数是完全可注射的,所以如果你有一个服务,例如myService,暴露了一个init()方法,你可以将其初始化为:

angular.module(...).run(['myService',function(myService) {
    myService.init();
}]);

如果服务初始化代码放在服务构造函数中,即:

angular.module(...).service(function() {
    ...initialization code...
});

…然后只需在run()方法中声明对服务的依赖就足够了,即:

angular.module(...).run(['myService',function() {
    // nothing else needed; the `myService` constructor,containing the
    // initialization code,will already have run at this point
}]);

实际上,您可以将其缩写如下:

angular.module(...).run(['myService',angular.noop]);

(旁注:我发现这种模式有点尴尬;如果服务只包含初始化代码,只需在run()函数中直接实现初始化代码.无论如何,你可以将多个run()函数附加到每个模块.)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读