0.背景

我们前面一篇文章简单介绍了angular如何引用其他组件,这篇文章简单介绍一下angualr组件之间如何传输数据。

一个使用场景:

我们定义了一个学生组件,学生有自己的姓名、年龄,语文成绩、数学成绩、英语成绩,然后其他地方调用学生组件。

那么会有一个问题,我们可能在很多地方调用学生组件,但是每个学生的姓名年龄不一定相同,如果我们都传入同样的名字那么学生组件显示的时候就一模一样了,为了解决这个问题,我们可以:

1.学生组件内置网络请求,每次打开组件都去后台请求数据然后渲染组件(但是至少要有一个具体的学生标记,比如我们前面说的路由跳转那种,但路由跳转是跳转到新页面,不符合我们要求)

2.组件之间传递参数

我们下面主要说 组件之间如何传递参数

1.input组件传参

我们执行

ng g c student

创建一个学生组件,

HTML文件参考:

<div>
  <h1>学生姓名:{{name}}</h1>
  <h2>学生年龄:{{age}}</h2>
  <h2>语文成绩:{{score.chinese}}</h2>
  <h2>数学成绩:{{score.math}}</h2>
  <h2>英语成绩:{{score.english}}</h2>
</div>  

ts文件参考:

import { Component, Input, OnInit } from '@angular/core';

@Component({
  selector: 'app-student',
  templateUrl: './student.component.html',
  styleUrls: ['./student.component.css']
})
export class StudentComponent implements OnInit {
  @Input() name:string      //学生姓名
  @Input() age:number       //学生年龄
  //成绩
  @Input() score:{
    chinese:number   //语文成绩
    math:number      //数学成绩
    english:number   //英语成绩
  }

  constructor() { }
  ngOnInit() {
  }
}

我们参考上面的方式定义了一个学生组件,参数有name,age和score对象。

然后我们在需要的地方引入组件,参考下面这样:

然后运行项目后,页面显示如下:

这是因为我们没有student组件传递参数

我们可以参考下面的方式给student组件传递参数:

<app-student
name="张三"
age="14"
[score]="{
  chinese:12,
  math:143,
  english:34
}"
></app-student>

对象形式要加“[]”

这种形式我们可以在html中直接传递参数,效果如下:

但是上面这种形式一般不用于实际开发,我们很少在html中直接传递参数, 一般用变量来传递,那么其实很简单,我们在app组件中定义下面这些变量

  myName='李四'
  myAge=14
  myScore={
    myChinese:95,
    myMath:113,
    myEnglish:54,
  }

然后在HTML中参考下面这样引用就能正常使用了

<app-student
[name]="myName"
[age]="myAge"
[score]="{
  chinese:myScore.myChinese,
  math:myScore.myMath,
  english:myScore.myEnglish
}"
></app-student>

效果跟上面类似。