首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用ES6扩散操作符传递道具

使用ES6扩散操作符传递道具
EN

Stack Overflow用户
提问于 2021-07-28 16:50:17
回答 1查看 53关注 0票数 1

ChildComponent.ts

代码语言:javascript
复制
export class ChildComponent implements OnInit {
  @Input() name?: string;
  @Input() email?: string;
  // A lot more props

  constructor() {}

  ngOnInit(): void {}
}

ParentComponent.ts

代码语言:javascript
复制
export class ParentComponent implements OnInit {
  childProps = {
    name: "johnny",
    email: "johnny@gmail.com"
  };

  constructor() {}    
  ngOnInit(): void {}
}

ParentComponent.html

这是可行的:

代码语言:javascript
复制
<app-child [name]="childProps.name" [email]="childProps.email"></app-child>

但是我如何使用ES6传播运算符传递所有道具呢?

代码语言:javascript
复制
<app-child [*]="{...childProps}"></app-child>
EN

回答 1

Stack Overflow用户

发布于 2021-07-28 22:54:35

你可以考虑为道具定义一个接口,然后作为一个对象传递,不需要传播或使用多个@Inputs()

代码语言:javascript
复制
// child.ts

export interface ChildProps {
  name?: string,
  email?: string  ​
}

export class ChildComponent implements OnInit {
 ​@Input() allProps?: ChildProps;
​
 ​constructor() {}

 ​ngOnInit(): void {}
}
代码语言:javascript
复制
//parent.ts

export class ParentComponent implements OnInit {
  childProps = {
    name: "johnny",
    email: "johnny@gmail.com"
  };

  constructor() {}    
  ngOnInit(): void {}
}
代码语言:javascript
复制
<!-- parent-template.html -->

<app-child [allProps]="childProps"></app-child>
代码语言:javascript
复制
<!-- child-template.html -->

<div>{{ allProps?.name }}</div>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68557230

复制
相关文章

相似问题

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