首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >与角性质性质的直接结合

与角性质性质的直接结合
EN

Stack Overflow用户
提问于 2020-02-02 14:50:29
回答 4查看 1.4K关注 0票数 2

我有个这样的模特:

代码语言:javascript
运行
复制
export class Person{
name: string;
}

它用于我的组件中,如下所示:

代码语言:javascript
运行
复制
export class TestComponent {
  @Input() person : Person;
  constructor() {
  }
}

我希望将html中的人名设置为:

代码语言:javascript
运行
复制
<app-test [person.name]="'Jack'"</app-test>

当我这么做的时候,angular很生气:“不能绑定到'person.name‘,因为它不是’app-test‘的一个已知属性。”

嗯,他是对的,人是我的财产,而不是person.name

另一方面,我们在以下示例中没有任何错误:

代码语言:javascript
运行
复制
<span [style.color]="'red'">This span is red.</span>

我是在违反规则吗?

还是风格属性在内部是不同的?多么?

谢谢

EN

回答 4

Stack Overflow用户

发布于 2020-02-02 15:15:37

不能绑定到person.name,因为输入()装饰器绑定到子组件(test)中的人员,而不是像person.name这样的任何特定属性

您必须发送一个对象来修复这个问题。

看这个示例

票数 2
EN

Stack Overflow用户

发布于 2020-02-02 15:17:15

你是对的,ngStyle是不同的,风格也不同,你需要

代码语言:javascript
运行
复制
<app-test [person]="{name:'Jack'}"</app-test>

其他选择包括

代码语言:javascript
运行
复制
<app-test [person]="person"</app-test>

在你的main.app里

代码语言:javascript
运行
复制
this.person.name='Jack'

请记住,如果在输入中使用对象,则父或子对象的属性的任何更改都会更改对象的“属性”。

票数 1
EN

Stack Overflow用户

发布于 2020-02-02 15:27:48

这是因为您试图传递给Test的输入属性是"person.name",它没有在您的Test上定义。您的需要一个名为"person“的东西。其次,您传递的是一个字符串,而不是您在Test组件上定义的Person类型。更改Test组件以接受字符串或传递Person,并在Test组件中引用name属性。并确保名称与匹配。

下面是两种可以考虑将人的姓名传递给另一个组件的方法

<app-test [name]="person.name" [person]="person"></app-test>

然后在Test组件中:

代码语言:javascript
运行
复制
 export class TestComponent  {
  @Input() name: string;
  @Input() person : Person;
}

注意到名字和类型是如何匹配的?我的建议是,不要超过你的需要。如果只需要传递Person名称,只需让组件接受一个字符串即可。不需要传递整个对象。

TestComponent模板:

代码语言:javascript
运行
复制
<h1>Person: {{person.name}}</h1>
<h1>Name: {{name}}</h1>

我将添加到角文档的链接,因为我认为它是角的一个非常重要的部分,您可能想回顾一下。他们的英雄教程真的很好。

https://angular.io/api/core/Input

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60027244

复制
相关文章

相似问题

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