Я использую компонент TabView с синтаксисом шаблона, чтобы перебирать его и добавлять элементы внутрь (используя наблюдаемую коллекцию и асинхронный канал). Мои элементы приходят из http-запроса.
Мой home.component.tns.html выглядит следующим образом:
<ActionBar title="Angular 2 Seed Advanced (nativescript)">
</ActionBar>
<StackLayout>
<TabView selectedIndex="0" selectedColor="#FF0000">
<template ngFor let-tab [ngForOf]="tabs | async">
<StackLayout *tabItem="tab">
<Label text="tab item"></Label>
</StackLayout>
</template>
</TabView>
<Button text="call something" (tap)="emptymethod()"></Button>
</StackLayout>
... и мой home.component.ts:
...
export class HomeComponent{
public tabs: Observable<any[]>;
constructor(private _menuService: MenuService) {
this._menuService.getMenu()
.map((menus) => {
let result: Array<any> = [];
if (menus) {
menus.forEach(menu => {
result.push({ 'title': menu.title });
});
}
return result;
})
.subscribe(
data => {
this.tabs = Observable.of<any[]>(data);
},
error => error => this._log.debug(error));
}
emptymethod() {
this._log.debug('HomeComponent - nada invoked');
}
ngOnInit() {
}
...
Когда интерфейс визуализируется, меню TabView не появляется, но когда я нажимаю кнопку вызвать что-то и вызывается emptymethod, элементы внутри TabView появляются, другими словами, после "обновления" появляется этот компонент...
Это не должно происходить автоматически?