如何在 Angular 2 中将对象从一个组件传递到另一个组件?
How to pass object from one component to another in Angular 2?
我有 Angular 个组件,第一个组件使用第二个组件作为 指令。
它们应该共享相同的模型 object,它在第一个组件中被初始化。
如何将该模型传递给第二个组件?
组件2,指令组件可以定义一个输入属性(Typescript中的@input
注解)。组件 1 可以将 属性 从模板传递给指令组件。
看到这个 SO 答案
以及如何将输入传递给子组件。在您的情况下,它是指令。
对于从父级到子级的单向数据绑定,使用 @Input
装饰器(根据样式指南 recommended)在子组件上指定一个输入 属性
@Input() model: any; // instead of any, specify your type
并在父模板中使用模板属性绑定
<child [model]="parentModel"></child>
由于您正在传递一个对象(JavaScript 引用类型),您对父组件或子组件中的对象属性所做的任何更改都将反映在另一个组件中,因为这两个组件都引用了同一个对象。我在 Plunker.
中展示了这个
如果在父组件中重新分配对象
this.model = someNewModel;
Angular 会将新对象引用传播到子组件(自动,作为更改检测的一部分)。
您唯一不应该做的就是重新分配子组件中的对象。如果这样做,父对象仍将引用原始对象。 (如果您确实需要双向数据绑定,请参阅 )。
@Component({
selector: 'child',
template: `<h3>child</h3>
<div>{{model.prop1}}</div>
<button (click)="updateModel()">update model</button>`
})
class Child {
@Input() model: any; // instead of any, specify your type
updateModel() {
this.model.prop1 += ' child';
}
}
@Component({
selector: 'my-app',
directives: [Child],
template: `
<h3>Parent</h3>
<div>{{parentModel.prop1}}</div>
<button (click)="updateModel()">update model</button>
<child [model]="parentModel"></child>`
})
export class AppComponent {
parentModel = { prop1: '1st prop', prop2: '2nd prop' };
constructor() {}
updateModel() { this.parentModel.prop1 += ' parent'; }
}
Plunker - Angular RC.2
使用输出注释
@Directive({
selector: 'interval-dir',
})
class IntervalDir {
@Output() everySecond = new EventEmitter();
@Output('everyFiveSeconds') five5Secs = new EventEmitter();
constructor() {
setInterval(() => this.everySecond.emit("event"), 1000);
setInterval(() => this.five5Secs.emit("event"), 5000);
}
}
@Component({
selector: 'app',
template: `
<interval-dir (everySecond)="everySecond()" (everyFiveSeconds)="everyFiveSeconds()">
</interval-dir>
`,
directives: [IntervalDir]
})
class App {
everySecond() { console.log('second'); }
everyFiveSeconds() { console.log('five seconds'); }
}
bootstrap(App);
您还可以将数据存储在具有 setter 的服务中,然后通过 getter
获取它
import { Injectable } from '@angular/core';
@Injectable()
export class StorageService {
public scope: Array<any> | boolean = false;
constructor() {
}
public getScope(): Array<any> | boolean {
return this.scope;
}
public setScope(scope: any): void {
this.scope = scope;
}
}
来自组件
import { Component, OnInit, ViewChild} from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { dataService } from "src/app/service/data.service";
@Component( {
selector: 'app-sideWidget',
templateUrl: './sideWidget.html',
styleUrls: ['./linked-widget.component.css']
} )
export class sideWidget{
TableColumnNames: object[];
SelectedtableName: string = "patient";
constructor( private LWTableColumnNames: dataService ) {
}
ngOnInit() {
this.http.post( 'getColumns', this.SelectedtableName )
.subscribe(
( data: object[] ) => {
this.TableColumnNames = data;
this.LWTableColumnNames.refLWTableColumnNames = this.TableColumnNames; //this line of code will pass the value through data service
} );
}
}
数据服务
import { Injectable } from '@angular/core';
import { BehaviorSubject, Observable } from 'rxjs';
@Injectable()
export class dataService {
refLWTableColumnNames: object;//creating an object for the data
}
到组件
import { Component, OnInit } from '@angular/core';
import { dataService } from "src/app/service/data.service";
@Component( {
selector: 'app-linked-widget',
templateUrl: './linked-widget.component.html',
styleUrls: ['./linked-widget.component.css']
} )
export class LinkedWidgetComponent implements OnInit {
constructor(private LWTableColumnNames: dataService) { }
ngOnInit() {
console.log(this.LWTableColumnNames.refLWTableColumnNames);
}
createTable(){
console.log(this.LWTableColumnNames.refLWTableColumnNames);// calling the object from another component
}
}
我有 Angular 个组件,第一个组件使用第二个组件作为 指令。 它们应该共享相同的模型 object,它在第一个组件中被初始化。 如何将该模型传递给第二个组件?
组件2,指令组件可以定义一个输入属性(Typescript中的@input
注解)。组件 1 可以将 属性 从模板传递给指令组件。
看到这个 SO 答案
以及如何将输入传递给子组件。在您的情况下,它是指令。
对于从父级到子级的单向数据绑定,使用 @Input
装饰器(根据样式指南 recommended)在子组件上指定一个输入 属性
@Input() model: any; // instead of any, specify your type
并在父模板中使用模板属性绑定
<child [model]="parentModel"></child>
由于您正在传递一个对象(JavaScript 引用类型),您对父组件或子组件中的对象属性所做的任何更改都将反映在另一个组件中,因为这两个组件都引用了同一个对象。我在 Plunker.
中展示了这个如果在父组件中重新分配对象
this.model = someNewModel;
Angular 会将新对象引用传播到子组件(自动,作为更改检测的一部分)。
您唯一不应该做的就是重新分配子组件中的对象。如果这样做,父对象仍将引用原始对象。 (如果您确实需要双向数据绑定,请参阅
@Component({
selector: 'child',
template: `<h3>child</h3>
<div>{{model.prop1}}</div>
<button (click)="updateModel()">update model</button>`
})
class Child {
@Input() model: any; // instead of any, specify your type
updateModel() {
this.model.prop1 += ' child';
}
}
@Component({
selector: 'my-app',
directives: [Child],
template: `
<h3>Parent</h3>
<div>{{parentModel.prop1}}</div>
<button (click)="updateModel()">update model</button>
<child [model]="parentModel"></child>`
})
export class AppComponent {
parentModel = { prop1: '1st prop', prop2: '2nd prop' };
constructor() {}
updateModel() { this.parentModel.prop1 += ' parent'; }
}
Plunker - Angular RC.2
使用输出注释
@Directive({
selector: 'interval-dir',
})
class IntervalDir {
@Output() everySecond = new EventEmitter();
@Output('everyFiveSeconds') five5Secs = new EventEmitter();
constructor() {
setInterval(() => this.everySecond.emit("event"), 1000);
setInterval(() => this.five5Secs.emit("event"), 5000);
}
}
@Component({
selector: 'app',
template: `
<interval-dir (everySecond)="everySecond()" (everyFiveSeconds)="everyFiveSeconds()">
</interval-dir>
`,
directives: [IntervalDir]
})
class App {
everySecond() { console.log('second'); }
everyFiveSeconds() { console.log('five seconds'); }
}
bootstrap(App);
您还可以将数据存储在具有 setter 的服务中,然后通过 getter
获取它import { Injectable } from '@angular/core';
@Injectable()
export class StorageService {
public scope: Array<any> | boolean = false;
constructor() {
}
public getScope(): Array<any> | boolean {
return this.scope;
}
public setScope(scope: any): void {
this.scope = scope;
}
}
来自组件
import { Component, OnInit, ViewChild} from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { dataService } from "src/app/service/data.service";
@Component( {
selector: 'app-sideWidget',
templateUrl: './sideWidget.html',
styleUrls: ['./linked-widget.component.css']
} )
export class sideWidget{
TableColumnNames: object[];
SelectedtableName: string = "patient";
constructor( private LWTableColumnNames: dataService ) {
}
ngOnInit() {
this.http.post( 'getColumns', this.SelectedtableName )
.subscribe(
( data: object[] ) => {
this.TableColumnNames = data;
this.LWTableColumnNames.refLWTableColumnNames = this.TableColumnNames; //this line of code will pass the value through data service
} );
}
}
数据服务
import { Injectable } from '@angular/core';
import { BehaviorSubject, Observable } from 'rxjs';
@Injectable()
export class dataService {
refLWTableColumnNames: object;//creating an object for the data
}
到组件
import { Component, OnInit } from '@angular/core';
import { dataService } from "src/app/service/data.service";
@Component( {
selector: 'app-linked-widget',
templateUrl: './linked-widget.component.html',
styleUrls: ['./linked-widget.component.css']
} )
export class LinkedWidgetComponent implements OnInit {
constructor(private LWTableColumnNames: dataService) { }
ngOnInit() {
console.log(this.LWTableColumnNames.refLWTableColumnNames);
}
createTable(){
console.log(this.LWTableColumnNames.refLWTableColumnNames);// calling the object from another component
}
}