微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Angular 父子组件传值

Angular 父子组件传值 @Input  @Output  @ViewChild

   

分享图片

新建一个头部组件 newsheader

  

分享图片

  在主组件引用 news 组件,在news组件添加 newsheader 组件。

设置newsheader组件样式

设置newsheader组件的内容添加一个class属性

<h2 class="header">这是一个头部组件</h2>

 如果需要全局设置,则在 style.css 中设置。

分享图片

如果单独设置自己的,则在自己组件的css中设置。

分享图片

此项目案例设置全局的。

/* You can add global styles to this file,and also import other style files */

.header{
    height: 44px;
    line-height: 44px;
    text-align: center;
    background-color: #000;
    color: #fff;
    text-align: center;
}

分享图片

把新闻页面的数据传给头组件(父组件向子组件传值)

 首先在新闻界组件定义一个数据(在父组件定义一个数据)

 在父组件中创建一个变量,用于传递给子组件:

 public message = "这是新闻组件的MSG"

 

分享图片

这个 message 属性属于新闻组件(父组件),我们可以在新闻组件上打印出来。

<app-newsheader></app-newsheader>
<hr>
这是新闻组件 -----  {{message}}
<hr>
<br>

分享图片

分享图片

在头部组件(子组件)中并没有定义 message 属性,我们在头部(子组件)是拿不到数据的,他们数据不能共享,因此我们需要通过父组件把需要的值(message)传给子组件。

1.父组件调用子组件的时候传入数据

<app-newsheader [msg]="message"></app-newsheader>

 

分享图片

2.子组件引入 Input 模块

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

 

分享图片

3.接收父组件传进的数据

@input() msg:string; /**通过Input接收父组件传进的msg */

 

分享图片

4.在头部(子组件)使用父组件传进的数据 msg

<h2 class="header">这是一个头部组件 -- {{msg}}</h2>

分享图片

分享图片

如果多个变量就添加多个HTML属性

假如 父组件 ts 文件有两个属性需要传给子组件

分享图片

父组件调用子组件的HTML代码也传入两个属性

分享图片

子组件在去接收父组件传进的两个值

分享图片

子组件就可以使用了

分享图片

分享图片

子组件执行父组件的方法

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐