- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我的 Angular 应用程序的模块有以下路由路径:
@NgModule({
imports: [
RouterModule.forChild([
{
path: 'documents',
data: { myObject: MyConstants.OPTION_ONE },
children: [
{
path: ':ID_DOC',
children: [
{ path: 'edit', component: EditDocumentComponent },
{ path: '', component: DocumentDetailsComponent },
]
},
{ path: 'add', component: AddDocumentComponent },
{ path: '', component: DocumentsListComponent }
]
}
])
],
exports: [
RouterModule
]
})
export class DocumentsManagementRoutingModule {
}
如您所见,我使用 data
属性将一些数据传递到“文档”中的每个路径,因此我可以从路由路径中声明的任何组件中获取它:
例如,我如何在 DocumentDetailsComponent
中获取数据:
export class DocumentDetailsComponent implements OnDestroy {
private obsData: Subscription;
private option: any;
constructor(private route: ActivatedRoute) {
this.obsData = this.route.data.subscribe(data => {
this.option = data['myObject'];
});
}
ngOnDestroy(): void {
this.obsData.unsubscribe();
}
}
现在我改变了整个应用程序的路由结构,我从其他模块调用上面的模块,在延迟加载中,使用 loadChildren
属性。我以同样的方式传递数据:
@NgModule({
imports: [
RouterModule.forChild([
{
path: 'users',
loadChildren: 'app/documents/documents.module#DocumentsModule',
data: { myObject: MyConstants.OPTION_ONE }},
{
path: ':ID_USER',
children: [
{ path: 'edit', component: EditUserComponent },
{ path: '', component: UserDetailsComponent },
]
},
{ path: 'add', component: AddUserComponent },
{ path: '', component: UserListComponent }
])
],
exports: [
RouterModule
]
})
export class UsersManagementRoutingModule {
}
我对调用 DocumentsManagementRoutingModule
的所有其他模块执行相同操作,将 myObject
属性更改为 MyConstants.OPTION_TWO
,MyConstants .OPTION_THREE
等等,根据我的需要。
那么,由于不知道调用懒加载模块的模块及其相关路径,如何从调用模块获取data
属性呢?
最佳答案
我想我可能明白问题在问什么。
这是@smartmouse提供的plunker的路由图。
- home
- shop
- contact
- map
- about
home
路由配置中配置了一个data
对象。直接子路由可以访问这个数据对象。问题是,非直接子 map
想要访问 data
对象,但显然,它不能。
我们可以知道@smartmouse 想要进一步插入 -- 嵌套的非直接子路由可以访问来自祖先的数据。
查看我修改过的plunker。 https://plnkr.co/edit/FA7mGmspUXHhU8YvgDpT
你可以看到我为contact
定义了一个额外的子组件DefaultComponent
。它表明它是路由 contact
的直接和默认子节点,可以解释为它也是上级路由 home
的直接子节点。因此,它可以访问 data
对象。
再看看我提供的plunker。
NOTE: The Angular packages I'm using is v4.3.0
我在 home.component.ts
中为 contact
路由定义了一些查询参数。您可以看到如何使用它。
优点:
缺点:
您不能在路由配置中定义查询参数。
但是您可以使用一些路由生命周期钩子(Hook)来为目标祖先路由定义它们
在作为单例模式的应用程序的顶层定义数据共享服务。另外,使用一些实用程序来防止它被启动两次。然后您可以将一些数据放入其中,并在任何地方检索它。
优点:
缺点:
有人可能会发现我还在plunker 中定义了resolve
示例代码。这是为了表明它具有与路由配置中的 data
相同的行为,除了它实际上是用于动态数据检索。
https://vsavkin.com/angular-router-understanding-router-state-7b5b95a12eab#5400
The data property is used for passing a fixed object to an activated route. It does not change throughout the lifetime of the application. The resolve property is used for dynamic data.
以@smartmouse 的 plunkr 为例。
我们在“home”路由配置中定义了data
。我们可以在ContactModule
中为联系人的默认路由定义一个数据解析器,代理从上级路由传过来的数据。然后它的所有直接子路由都可以访问解析的数据对象。
优点:
缺点:
Angular 的普遍使用目前还没有完美和通用的解决方案。有人应该权衡利弊并选择合适的。
关于 Angular 路由器 : how to pass data to lazy loading module?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44919379/
我有 4 个文件。 C:\perlCode2\start.pl6 C:\perlCode2\file0.pm6 C:\perlCode2\folder1\file1.pm6 C:\perlCode2\
我有一个结构如下的模块: /module __init__.py /submod_1 __init__.py submod_1_class.py
我的源代码在 java 7 上编译并在 java 11 上运行。 我正在尝试将 imperva RASP 作为 java 代理集成到 tomcat 中。但是,当我启动 tomcat 服务器时,它抛出以
justExport.js const first = () => { console.log('frist from justExport') } const second = () => {
以下模块用JS文件编写: module.exports = { propA: 1, propB: 2 } 允许稍后从模块导入属性,如:从“路径/到/模块”导入 { propA} 然而,将文件格
我一直在尝试在嵌套的惰性加载模块中实现ngx翻译,但一直未能如愿。我面临的唯一问题是,每当我通过选择器更改语言时,嵌套延迟加载模块中的语言都不会更改。 HttpLoader 工作正常,其他一切工作正常
我没有可重复的示例,因为问题更多是关于模块如何工作。我试图了解如何将一些 react 功能从一个模块传递到下一个模块。过去我收到过有关使用 ObserveEvent 的回复,但是当我在一个模块中使用响
我正在阅读Wikipedia's definition of Dependency inversion principle ,它使用了两个术语高级模块和低级模块,我无法弄清楚。 它们是什么以及依赖倒置
问题 我遇到的一个问题是将两个模块的类型和值带入一个新的组合模块中。我举个例子。目前我有以下两种类型签名 module type Ordered = sig type t (* the type
我是 JavaScript 的新手,最近一直在努力处理导入问题。有一件事我无法理解。 在较旧的节点模块(主要是那些在 ES6 之前出现的模块)中,可以使用 npm 安装,例如 express,通常没有
我正在尝试使用 System.JS 将 material-ui 导入我的 React 应用 在我的应用中,我这样做: import {AppBar, Tabs, Tab, Card, CardTitl
我想使用功能module->exports查找模块提供的所有导出。不幸的是,传递给该函数的模块必须在当前命名空间中声明,然后才能在其上使用该函数。当我静态地知道模块是什么时,这没问题,我只需要将其引入
目录结构如下 outdir |--lib |--- __init__.py |--- abc.py |--indir
这与提到的非常相似 here但是评论或回答中提供的每个解决方案都没有解决我的问题。想看看是否还有其他我应该看的东西。我尝试了不同的路径,比如 ./app/mycomponent/mycomponent
我有两个 Angular 模块:main 和 feature: 主/根模块: @NgModule({ imports: [ StoreModule.forRoot({route
我尝试在 Ubuntu 04.12 LTS x64 中安装“Userful MultiSeat-X64-5.0.1 ...”,在安装结束时遇到以下错误: File "", line 6, in Im
我正在尝试优化我的 vendor bundle.js,因为它已经膨胀并且我正在使用 material-ui 库。 import Card from 'material-ui'; // Very bad
错误: Import-Module : The specified module 'msonline' was not loaded because no valid module file was
我在 Server 2008 SP2(64 位)上执行导入模块 ActiveDirectory 时遇到问题。 NET Framework 3.5 SP1 已安装 我下载了 Windows6.0-KB9
嗯,你好! 我正在编写一个脚本来获取 Sql 作业历史记录,并且需要使用“SqlServer”模块。它已安装,但由于上面的错误消息,我无法导入它。当我到达模块路径时,文件夹“SqlServer”存在并
我是一名优秀的程序员,十分优秀!