首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用routerLink传递对象

用routerLink传递对象
EN

Stack Overflow用户
提问于 2019-05-24 09:34:46
回答 4查看 11.2K关注 0票数 0

我想用routerLink传递一个对象。我找到了很多,但没有得到满意的答案。我对角质很陌生。

user.component.html

代码语言:javascript
运行
复制
<button type="button" routerLink="/admin">Add Event</button>

user.component.ts

代码语言:javascript
运行
复制
export class UserComponent implements OnInit {

  @Input()
  public user: UserOperator = new UserOperator({});

我想把上面的用户对象传递给有按钮的routerLink。

app.module.ts

代码语言:javascript
运行
复制
const appRoutes: Routes = [
  { path: 'admin', component: AdminComponent },
]

我的工作角度7。任何帮助将不胜感激。

EN

Stack Overflow用户

发布于 2019-05-24 09:48:42

您可以将对象编码到字符串中,并通过查询参数传递它。

component.html

代码语言:javascript
运行
复制
<button type="button" [routerLink]="[getLink()]">Add Event</button>

component.ts

代码语言:javascript
运行
复制
...

getLink(): string {
    return `/admin?state=${btoa(JSON.stringify(this.user))}`;
}

...

another.component.ts

代码语言:javascript
运行
复制
constructor(private route: ActivatedRoute) {}

ngOnInit(): void {
   this.route.queryParams.subscribe(params => { 
       let user = new UserOperator(JSON.parse(atob(params['state']))); 
   });
}
票数 3
EN
查看全部 4 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56289773

复制
相关文章

相似问题

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