SAP 电商云 Spartacus UI product 明细页面的路由配置

如果直接访问如下 url:
http://localhost:4200/powerto...

SAP 电商云 Spartacus UI product 明细页面的路由配置_第1张图片

页面打开后,没有看到和 product 相关的执行逻辑:

SAP 电商云 Spartacus UI product 明细页面的路由配置_第2张图片

SAP 电商云 Spartacus UI product 明细页面的路由配置_第3张图片

这个 cxRoute: 'product' 是哪里维护的?

SAP 电商云 Spartacus UI product 明细页面的路由配置_第4张图片

SAP 电商云 Spartacus UI product 明细页面的路由配置_第5张图片

看这个高亮区域是从哪里赋值的?
SAP 电商云 Spartacus UI product 明细页面的路由配置_第6张图片

在 routing.module.js 里,一个初始化钩子:

SAP 电商云 Spartacus UI product 明细页面的路由配置_第7张图片

调试 35行这个 router 是如何被计算出来的即可:

SAP 电商云 Spartacus UI product 明细页面的路由配置_第8张图片

通过依赖注入完成的:
SAP 电商云 Spartacus UI product 明细页面的路由配置_第9张图片

根据如下关键字搜索:cxRoute: 'product
SAP 电商云 Spartacus UI product 明细页面的路由配置_第10张图片

必须和 default-routing-config.ts 里定义的这个 product 字符串的大小写完全一致:

SAP 电商云 Spartacus UI product 明细页面的路由配置_第11张图片

最后发现了 product-details-page.module.ts 里调用了 Angular 标准的路由 API:RouterModule.forChild

SAP 电商云 Spartacus UI product 明细页面的路由配置_第12张图片

component:路径匹配时实例化的组件。Spartacus UI 里使用的是 PageLayoutComponent,这是一个 generic Component.

SAP 电商云 Spartacus UI product 明细页面的路由配置_第13张图片

data 属性:ActivatedRoute 提供给组件的由开发人员定义的额外数据。默认情况下,不传递任何额外数据。

Spartacus UI 传递了 cxRoute: 'product' 作为额外属性。

做个实验,把 ProductDetailsPageModule 的路由配置里的 cxRoute,改成 login:

SAP 电商云 Spartacus UI product 明细页面的路由配置_第14张图片

路由就挂了:

SAP 电商云 Spartacus UI product 明细页面的路由配置_第15张图片

更多Jerry的原创文章,尽在:"汪子熙":

你可能感兴趣的:(SAP 电商云 Spartacus UI product 明细页面的路由配置)