首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有动态组件的角URL(路由)定制

带有动态组件的角URL(路由)定制
EN

Stack Overflow用户
提问于 2021-05-26 14:01:13
回答 1查看 65关注 0票数 0

我做了一个角度项目(摩托车电子商务),显示产品详细信息的组件负责所有产品,因此这个组件的路由总是相同的:

代码语言:javascript
复制
https://fakeweb.com/second-hand-bikes/details?bikeId=7440483

这会导致所有产品对google都有相同的链接(因为google忽略参数?bikeId=……)

我的问题是:如何根据获取的产品定制urls ?,如下所示:

代码语言:javascript
复制
https://fakeweb.com/second-hand-bikes/details/yamaha-xmax-300

我想做一个脚本,为每次在后端添加新产品时手动创建路径,但看起来是一个痛苦的解决方案。

有什么想法吗?谢谢您的任何帮助!

EN

回答 1

Stack Overflow用户

发布于 2021-05-26 14:26:36

显示特定产品详细信息的组件的路由将需要该产品名称的路由参数。我们可以使用以下路由来实现这一点:

代码语言:javascript
复制
export const routes: Routes = [
  [...]
  { path: 'second-hand-bikes/details/:name', component: ProductDetails }
];

ProductDetails组件必须读取参数,然后根据参数中给定的名称加载产品。ActivatedRoute服务提供了一个params Observable,我们可以订阅它来获取路由参数:

代码语言:javascript
复制
productName: string;
private sub: any;

constructor(private route: ActivatedRoute) {}

ngOnInit() {
  this.sub = this.route.params.subscribe(params => {
     this.productName = params['name'];

     // In a real app: dispatch action to load the details here.
  });
}

ngOnDestroy() {
  this.sub.unsubscribe();
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67706535

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档