使用 dart 为 angular2 组件定义提供者

defining providers for an angular2 component using dart

我正在使用 Intellij 编写一个 angular2 dart 应用程序。

我创建了一个名为 Auth 的提供程序,它应该被注入到应用程序组件中。

我使用以下代码定义了 Auth 服务:

import 'package:angular2/core.dart';
import 'package:auth0_lock/auth0_lock.dart';
import './config.dart';

@Injectable()
class Auth {
Auth0Lock lock;

Auth() {
    this.lock = new Auth0Lock(configObj.auth0.apiKey, configObj.auth0.domain);
}
updateProfileName(data) {
  var profile = data['profile'] != null ? data['profile'] : data;
  print(profile['name']);
}

login() {
    this.lock.show(popupMode: true, options: {'authParams': {'scope': 'openid profile'}}).then(this.updateProfileName);
}
}

和使用以下代码的应用程序组件:

import 'package:angular2/core.dart';
import 'package:angular2/router.dart';
import 'welcome_component.dart';
import 'auth_service.dart';

@Component(
    selector: 'my-app',
    templateUrl: '/www/my-app.html',
   providers: [Auth]
)
@RouteConfig(const [
  const Route(path: '/welcome', component: WelcomeComponent, name: 'welcome')
])
class AppComponent {
  Auth auth;
  AppComponent(Auth auth) {
    this.auth=auth;
  }
}

现在 intellij 正在使用错误消息 arguments of constant creation must be constant expressions.

抱怨提供者数组

我是 dart 的新手...但是如果组件配置需要常量,我如何提供 类 在那里使用?

谢谢

只需添加 const 即可:

providers: const [Auth]

您看到的错误是因为 [Auth] 创建了一个 List,尽管它只包含一个 const 成员,但它本身不是常量。 (例如,它可以添加到或清除。)Dart 要求您明确指定 List 是常量。