【发布时间】:2018-07-01 11:33:19
【问题描述】:
使用 Angular 5 和 UIRouter 状态路由。我正在根据这个接口使用一个额外的自定义路由状态属性。
interface AugmentedNg2RouteDefinition extends Ng2StateDeclaration {
default?: string | ((...args: any[]) => string | Promise<string>);
}
当我定义一个抽象状态时,我现在也可以向它添加一个default 属性,因此当尝试路由到抽象状态时,默认值应该将它们重定向到配置的默认值 子状态。
从上面的界面可以理解,default可以定义为以下任意一种:
// relative state name
default: '.child',
// absolute state name
default: 'parent.child',
// function with DI injectables
default: (auth: AuthService, stateService: StateService) => {
if (auth.isAuthenticated) {
return '.child';
} else {
return stateService.target('.login', { ... });
}
}
// function with DI injectables returning a promise
default: (items: ItemsService) => {
return items
.getTotal()
.then((count) => {
return count > 7
? '.simple'
: '.paged';
});
}
要真正让default 工作,我必须配置路由转换服务:
@NgModule({
imports: [
...
UIRouterModule.forChild({ // or "forRoot"
states: ...
// THIS SHOULD PROCESS "default" PROPERTY ON ABSTRACT STATES
config: (uiRouter: UIRouter, injector: Injector, module: StatesModule) => {
uiRouter.transitionService.onBefore(
// ONLY RUN THIS ON ABSTRACTS WITH "default" SET
{
to: state => state.abstract === true && !!state.self.default
},
// PROCESS "default" VALUE
transition => {
let to: transition.to();
if (angular.isFunction(to.default)) {
// OK WE HAVE TO EXECUTE THE FUNCTION WITH INJECTABLES SOMEHOW
} else {
// this one's simple as "default" is a string
if (to.default[0] === '.') {
to.default = to.name + to.default;
}
return transition.router.stateService.target(to.default);
}
}
);
}
})
]
})
export class SomeFeatureModule { }
所以问题在于调用default,当它是一个可能有一些可注入服务/值的函数时......
配置函数的注入器(config: (uiRouter: UIRouter, injector: Injector, module: StatesModule))只能用于获取服务实例,不能调用带有可注入参数的函数。
在 AngularJS 中,这将由 $injector.invoke(...) 完成,它会调用函数并注入其参数。
主要问题
当default 被定义为带有可注射的函数时,我应该如何处理它。
【问题讨论】:
-
问题是
default可以在某些时候起作用,但实际上并非如此。它到底是什么样子的? config 函数的 Injector 只能获取我不能在这里真正使用的注射剂实例 - 这是什么意思?这些实例是什么,哪些是预期的? stackoverflow.com/help/mcve 和明确的问题陈述在这里是必要的。 -
@estus:
default可以是字符串,也可以是返回字符串或字符串承诺的函数。问题是这个函数可能需要由 Angular 的 DI 容器提供的参数。这就是为什么人们会在 AngularJS 中使用$injector.invoke,但.invoke函数在我的 Angular 5 代码上下文中不可用。你现在明白问题了吗? -
Angular 中没有 $injector.invoke,支持 DI 的函数应该定义为提供者。这个函数和这些参数(服务?)是什么真的很重要。您的评论没有解释这一点,config 函数的 Injector 只能获取我在这里无法真正使用的注射剂实例。请使用详细解释您的案例的示例更新问题,因为一般无法解决该问题。
-
@estus 我知道没有
$injector.invoke。你认为我为什么首先问这个问题?我显然没有正确描述我的问题,因为您不了解defaultstate 属性的作用。因此,注入参数(当default是具有可注入参数的函数时)可能是任何提供信息以决定应选择哪个默认子状态的信息。即一些身份验证服务......对于那些真正仔细阅读它的人来说,我的问题已经足够详细了。这不是一些基本问题。这是一个提前问题。 -
@estus:我希望我经过严格编辑的问题现在更加清晰易懂。也可能是,我缺少一些知识,所以我不能让我的问题更清楚,因为它是 ATM。看来我错过了什么。
标签: angular typescript configuration routing angular5