Angularusingaserviceinanoncomponentfile
创始人
2024-10-29 21:30:36
0

在Angular中,我们可以使用服务来组织可重用的代码。然而,在一些非组件文件中使用服务可能会引起问题。比如,在一个常量或者一个JavaScript模块中使用服务。直接注入这个服务是不可行的。以下是一种

首先,我们需要在我们想要使用服务的非组件文件中引入它:

import { MyService } from './path-to-my-service.service';

请注意,这里我们使用了相对路径来引入服务。

接下来,我们需要使用Angular的注入器来获取这个服务的一个实例。为此,我们需要在文件的顶部定义注入器:

import { Injector } from '@angular/core'; export let AppInjector: Injector;

export const setAppInjector = (injector: Injector) => { if (AppInjector) { console.error('AppInjector was already set'); } else { AppInjector = injector; } };

上面的代码中,我们定义了一个注入器AppInjector并暴露一个setAppInjector函数,使得我们可以在整个应用中共享注入器。

最后,在应用启动时,我们需要使用主模块中的一个注入器实例来设置AppInjector:

@NgModule({ imports: [ // ... ], declarations: [ // ... ], providers: [ // ... ], bootstrap: [AppComponent] }) export class AppModule { constructor(private injector: Injector) { setAppInjector(injector); } }

现在,我们就可以在非组件文件中使用MyService服务了:

const myService = AppInjector.get(MyService); myService.doSomething();

相关内容

热门资讯

第2分钟开挂!四川途游麻将开挂... 第2分钟开挂!四川途游麻将开挂,小程序边锋辅助,2025新版教程-2026最新版本1)四川途游麻将开...
目前来看!大菠萝怎么提高好牌几... 目前来看!大菠萝怎么提高好牌几率(辅助挂)其实确实有挂(有挂妙计)-哔哩哔哩;亲,大菠萝怎么提高好牌...
四分钟开挂!微信小程序微乐破解... 四分钟开挂!微信小程序微乐破解器,友友联盟辅助脚本,新2025教程-2026最新版本1、起透看视 微...
围绕透视问题!微乐河南小程序辅... 围绕透视问题!微乐河南小程序辅助器免费(辅助挂)一直真的有挂(有挂窍要)-哔哩哔哩;亲,微乐河南小程...
1分钟开挂!海洋麻将辅助器,天... 1分钟开挂!海洋麻将辅助器,天天微友有辅助吗,wepoke教程-2026最新版本天天微友有辅助吗辅助...
现有关情况通报如下!来物局怎么... 来物局怎么开挂 无需打开直接搜索微信:136704302本司针对手游进行,选择我们的四大理由: 1、...
八分钟开挂!潜江晃晃辅助,hh... 八分钟开挂!潜江晃晃辅助,hhpoker辅助实战视频,透明挂教程-2026最新版本亲,关键说明,hh...
据监测!福建天天开心辅助工具下... 据监测!福建天天开心辅助工具下载(辅助挂)一贯真的有挂(有挂教程书)-哔哩哔哩,福建天天开心辅助工具...
第五分钟开挂!花花生活圈脚本,... 第五分钟开挂!花花生活圈脚本,兴动互娱辅助器,技巧教程-2026最新版本1、兴动互娱辅助器透视辅助简...
目前!中至江西插件(辅助挂)一... 中至江西插件 无需打开直接搜索微信:136704302本司针对手游进行,选择我们的四大理由: 1、软...