AngularDart依赖注入

问题描述 投票:2回答:1

我正在使用AngularDart,我无法弄清楚如何注入我的入口点依赖项。

Main.dart:

import 'package:angular/angular.dart';
import 'package:angular_dart/app_component.dart';
import 'package:angular_dart/app_component.template.dart' as ng;

@GenerateInjector(const [
  const Provider(MyRepository, useClass: ng.MyRepositoryImpl),
])
final InjectorFactory appInjector = ng.appInjector$Injector;

void main() {
  runApp(ng.AppComponentNgFactory, createInjector: appInjector);
}

app_component.dart

import 'package:angular/angular.dart';

@Component(
  selector: 'app-component',
  templateUrl: 'app_component.html',
  providers: [ClassProvider(MyRepository)]
)
class AppComponent {
  MyRepository myRepository; //This is not getting injected
}

abstract class MyRepository {
}

class MyRepositoryImpl implements MyRepository {
}

我的问题是关于runApp方法和ng.AppComponentNgFactory。我没有看到注射是如何解决的。

提前致谢,

编辑:我正在寻找的是如何告诉编译器生成如下行:

new AppComponent(new MyRepositoryImpl);

并像消费它一样

class AppComponent{
final MyRepository _repo;

AppComponent(MyRepository repo) {
this._repo = repo;
}
}
angular dependency-injection dart angular-dart
1个回答
2
投票

[ClassProvider(MyRepository)]中使用app_component告诉编译器覆盖你在main.dart文件中设置的内容。

试试这个:

@Component(
  selector: 'app-component',
  templateUrl: 'app_component.html',
)
@Injectable()
class AppComponent {
  final MyRepository _myRepository;

  AppComponent(this._myRepository);
}

编辑:

您的main.dart文件不正确,您必须从main.template.dart引用注入器:

import 'package:angular/angular.dart';
import 'package:angular_dart/app_component.dart';
import 'package:angular_dart/app_component.template.dart' as ng;
import 'main.template.dart' as self;

@GenerateInjector([
  ClassProvider(MyRepository, useClass: ng.MyRepositoryImpl),
])
final InjectorFactory injector = self.injector$Injector;

void main() {
  runApp(ng.AppComponentNgFactory, createInjector: injector);
}
© www.soinside.com 2019 - 2024. All rights reserved.