我是Angular 2的新手,我想通過@Input()將一個在父組件中創建的數組傳遞給它的子節點。在@Input()之後,數組是否改變爲對象?
在父項中,我創建數組,從服務中添加數據並將其顯示在控制檯(控制檯輸出1)中。在子組件中,我使用ngOnChanges再次在控制檯中顯示它(控制檯輸出2)。正如你在下面看到的,數組的長度從12變爲0.我想這是因爲當數組傳遞給子對象時,數組變成了對象?
我該如何解決這個問題?
父
import { Component, OnInit } from '@angular/core';
import { Module, MapMarkerData } from './coreclasses';
import { TimelineService } from './input.service';
@Component({
selector: 'my-app',
templateUrl: 'app/app.component.html',
providers: [TimelineService]
})
export class AppComponent implements OnInit {
modules: Module[];
mapMarkerData: any;
constructor(private timelineService: TimelineService) {
this.mapMarkerData = new Array<MapMarkerData>();
}
getModules(): void {
this.timelineService.getModules().then(modules => {this.modules = modules; this.setMapModuleData(this.modules);});
}
setMapModuleData(modules: Array<any>): void {
for (let module of modules) {
if (module.className) {
var id = module.id;
var className = module.className;
let contents: Object = {id: id, className: className};
this.mapMarkerData.push(contents);
}
}
console.log(this.mapMarkerData); // CONSOLE OUTPUT 1
console.log(this.mapMarkerData.length);
}
}
兒童
import { Component, Input, OnInit, OnChanges, SimpleChanges } from '@angular/core';
import { MapMarkerData } from './coreclasses';
@Component({
selector: 'timeline-map',
templateUrl: 'app/timeline.map.component.html'
})
export class TimelineMapComponent implements OnChanges {
@Input()
mapMarkerData: any;
ngOnChanges(changes: any) {
console.log(this.mapMarkerData); // CONSOLE OUTPUT 2
console.log(this.mapMarkerData.length);
}
}
父模板
...
<div id="map" class="mapLarge">
<timeline-map [mapMarkerData] = "mapMarkerData"></timeline-map>
</div>
...
控制檯輸出1 陣列[12]:[對象,對象,...]
控制檯輸出2 數組[0]:[對象,對象,...]
傳遞給孩子當陣列沒有改變。我懷疑'Console Output 2'是在'Console Output 1'之前打印的。情況並非如此嗎? –
更改由'changes.mapMarkerData.currentValue'訪問 – harshes53