我正在将我的应用切换到新的路由DSL。具体来说,我想使用preEnter
做这样的事情:
final RouteInitializerFn routes =(Router router, ViewFactory views) {
views.configure({
'chat': ngRoute(
path: '/chat',
// authService.requireState returns a Future<bool>, and may invoke an HttpRequest
preEnter: (RoutePreEnterEvent e) => e.allowEnter(authService.requireState(LOGGED_IN)),
view: 'views/chat.html'),
'login': ngRoute(
path: '',
defaultRoute: true,
view: 'views/login.html')
});
}
这将在模块中进行如下配置:
value(RouteInitializerFn, routes);
万一您错过了它,我在
authService
中引用了一个可注入(inject)的RouteInitializerFn
。这是不可能的,因为RouteInitializerFn
是一个函数而不是一个类,因此不能向其中注入(inject)任何内容。如果我将routes
函数封装在一个类中,则不确定如何配置RouteInitializerFn
,所以我有点困惑。 最佳答案
我找到了解决这个问题的不错的解决方案。事实证明,如果您在满足typedef的类上定义call
方法,则可以将其配置为typedef的实现。很酷。这是我的解决方案:
class Routes
{
final UserService _userService;
Routes(this._userService);
void call(Router router, ViewFactory views)
{
views.configure({
'chat': ngRoute(
path: '/chat',
preEnter: (RoutePreEnterEvent e) => e.allowEnter(this._userService.requireUserState(UserService.LOGGED_IN)),
view: 'views/chat.html'
),
'login': ngRoute(
path: '',
defaultRoute: true,
view: 'views/login.html'
)
});
}
}
这是它在模块中的配置方式:
// old syntax
type(RouteInitializerFn, implementedBy: Routes);
// new syntax
bind(RouteInitializerFn, toImplementation: Routes);
关于dart - 如何将服务注入(inject)RouteInitializerFn(新的路由DSL),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25980921/