新建一个Route module:
import { NgModule } from '@angular/core';
import { ConfigModule, OccConfig, RoutingConfig } from '@spartacus/core';
@NgModule({
declarations: [],
imports: [
ConfigModule.withConfig({
routing: {
routes: {
product: {
paths: [
'cameras/:productCode/:manufacturer/:name',
'cameras/:productCode/:name',
'cameras/:productCode/',
]
}
}
}
} as RoutingConfig),
ConfigModule.withConfig({
backend: {
occ: {
endpoints: {
productSearch:
// tslint:disable-next-line: max-line-length
'products/search?fields=products(code,manufacturer,name,summary,price(FULL),images(DEFAULT),stock(FULL),averageRating,variantOptions),facets,breadcrumbs,pagination(DEFAULT),sorts(DEFAULT),freeTextSearch,currentQuery',
},
},
},
} as OccConfig),
]
})
export class RoutingConfigurationModule { }
默认的路由url:product/productCode/productName
data:image/s3,"s3://crabby-images/de0a7/de0a7b268da3b080ba41bc36891bed7f6e14a60b" alt=""
我在TypeScript代码里维护的路由url里,包含了硬编码的camera,如下所示:
camera/productCode/productName
启用我自定义的路由module之后,运行时效果:
data:image/s3,"s3://crabby-images/07d67/07d6721af09e47c054747d21750254bfc7a9d5a1" alt=""
另一种包含了manufactor code的url:
data:image/s3,"s3://crabby-images/496a1/496a13d1b39a4239f2d7bcb1cc21e8ec5ca4a1c1" alt=""
这是因为我在api endpoint里,指定了将manufacturer字段一并取回:
data:image/s3,"s3://crabby-images/daeb8/daeb8c5056b4c4aeb14ce362ae488b842553089e" alt=""
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/5c245/5c2451227ab390a16b5fe9bdbec5d83178d7661c" alt=""
网友评论