16

在我的角度应用程序(使用角度材料)中,我有一个过滤器面板,除了选择之外,我还希望能够进行自动完成(用户输入值并将其发送到后端,由此 $regexp 查询我们在 MongoDB 集合中找到匹配项)。但要做到这一点,我需要手动将服务注入过滤器组件。我没有找到有关如何执行此操作的任何信息。

我需要这样的东西:

if (filters.serviceName) {
  injector.inject(serviceName);
}

injector.get(serviceName).find(searchQuery);

可能吗?谢谢。

4

2 回答 2

21

是的,您可以inject使用injector.get()动态服务

示例代码:

import { Component, Injector } from '@angular/core';
import { MyService } from './my.service';

@Component({
  selector: 'my-app',
  templateUrl: './app.component.html',
  styleUrls: [ './app.component.css' ]
})
export class AppComponent  {
  name = 'Angular';
  myService : MyService;

  constructor(private injector : Injector){
    if(true){ // some condition
      this.myService = injector.get<MyService>(MyService);
    }

    console.log(this.myService.prop1)
  }
}

工作演示

于 2018-08-31T07:11:56.670 回答
2

另一个变体使用@Inject装饰器,如果条件计算在当前类之外。

export interface IService {
  test: string;
}


@Injectable()
export class Serivce1 implements IService {
  test: 'service1';
}

@Injectable()
export class Serivce2 implements IService {
  test: 'service2';
}

const CONDITION = Math.random() > 0.5;
    
@Component({
   selector: 'my-app',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css'],
})
export class AppComponent {
   name = 'Angular ' + VERSION.major;
    
   constructor(@Inject(CONDITION ? Serivce1 : Serivce2) private service: IService) {
        console.warn(service);
   }
}
于 2021-12-14T05:55:01.887 回答