Home > Web Front-end > JS Tutorial > How to implement component interaction in Angular2

How to implement component interaction in Angular2

亚连
Release: 2018-06-19 17:14:06
Original
1668 people have browsed it

This article mainly introduces the method of realizing component interaction in Angular2, and summarizes and analyzes the relevant operating skills and precautions for component interaction in Angular2 in the form of examples. Friends in need can refer to the following

The examples in this article describe Angular2's method of implementing component interaction. Share it with everyone for your reference, the details are as follows:

Preface

In Angular development, we often involve the interaction between components , for example, referencing components developed by our own department
Sometimes, we need to bind some data to the referenced component, or we need the referenced subcomponent to output some data
At this time, we need to handle the relationship between the components Interaction between

Key code for component interaction

Bind data from parent component to child component

Subcomponent

<h3>{{hero.name}} says:</h3>
@Input() hero: Hero;
Copy after login

Parent component

<hero-child [hero]="myhero" ></hero-child>
myhero = "Mr.IQ";
Copy after login

The @Input of the subcomponent here indicates that it needs the entity hero. Later, when the parent component introduces the subcomponent, it must be written in the subcomponent tag. Enter hero, and assign a value to hero in your own component to bind the parent component data to the child component

The parent component listens to the events of the child component

The child component

<button (click)="vote(true)" >Agree</button>
@Output() onVoted = new EventEmitter<boolean>();
vote(agreed: boolean) { this.onVoted.emit(agreed);}
Copy after login

Parent component

<my-voter (myonVoted)="onVoted($event)"></my-voter>
myonVoted(agreed: boolean) { agreed ? this.agreed++ : this.disagreed++; }
Copy after login

The @Output of the child component indicates that it will use the onVoted method to pass a boolean value to the parent component. After the parent component introduces the child component, it binds the child component's method By going to your own method, you can achieve the effect of monitoring sub-components

setter intercepts changes in input attribute values

Sub-component

<h3>"{{name}}"</h3>
private _name = &#39;&#39;;
@Input()
set name(name: string) { this._name = (name && name.trim()) || &#39;<no name set>&#39;; }
get name(): string { return this._name; }
Copy after login

Parent Component

<name-child [name]="myname"></name-child>
Copy after login

After the parent component references the child component, it binds data to the child component. The child component modifies and displays the data passed by the parent component through set and get

The parent component and Subcomponents interact through local variables

Subcomponent

seconds = 11;
stop() { this.message = `Holding at T-${this.seconds} seconds`;  }
Copy after login

Parent component

<button (click)="timer.stop()">Stop</button>
<p class="seconds">{{timer.seconds}}</p>
<countdown-timer #timer></countdown-timer>
Copy after login

The subcomponent defines variables and methods. After the parent component refers to the subcomponent tag, pass Create a local variable in the label to represent the sub-component, and then use the variable to access the variables and methods of the sub-component

The above is what I have compiled for everyone. I hope it will be helpful to everyone in the future.

Related articles:

How to implement orderBy sorting and fuzzy query in Angular

vue vuex vue-rouert permission routing (detailed tutorial )

How to get the keyCode of the keyboard in javascript

The above is the detailed content of How to implement component interaction in Angular2. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template