2016-07-19 6 views
0

У меня возникли проблемы с использованием обещания вернуть объект степени в Angular 2. Первый оператор возврата (без рамок) в degree.service работает просто отлично в сочетании с неоформленной реализацией getDegree() в build.component. Однако, когда я пытаюсь переключиться на любой из комментируемых реализаций, используя обещание, объект всегда возвращается как «неопределенные»Вопросы с угловым 2 обещанием объекта передачи

degree.service.ts

import { Injectable } from '@angular/core'; 

import { Degree } from '../components/degree'; 
import { Category } from '../components/category'; 
import { Course } from '../components/course'; 

import { SAMPLE } from '../components/mock-degree'; 

@Injectable() 
export class DegreeService{ 
    getDegree(){ 
    return SAMPLE; 
    // return Promise.resolve(SAMPLE); 
    // return new Promise<Degree>(function (resolve, reject) { 
    // resolve(SAMPLE); 
    // }) 
    } 
} 

build.component.ts

import { Component, Input, OnInit } from '@angular/core'; 
import { SEMANTIC_COMPONENTS, SEMANTIC_DIRECTIVES } from "ng-semantic"; 

import { Course } from '../course'; 
import { Category } from '../category'; 
import { PaneComponent } from './pane/pane.component'; 
import { Degree } from '../degree'; 

import { DegreeService } from '../../services/degree.service'; 


const blank: Category = { 
    name: '', 
    rank: 1, 
    rulestat: 'no', 
    categories: [], 
    courses: [] 
} 

@Component({ 
    selector: 'my-build', 
    directives: [SEMANTIC_COMPONENTS, SEMANTIC_DIRECTIVES, PaneComponent], 
    templateUrl: `app/components/build/build.component.html`, 
    providers: [DegreeService] 
}) 



export class BuildComponent implements OnInit{ 
    constructor(private degreeService: DegreeService){} 

    level: number = 1; 
    currDeg: Degree; 
    parents = [blank, blank, blank, blank]; 


    setLast(lst: Category){ //pass category objects, do all UI changing here 
    this.level = lst.rank + 1; 
    this.parents[lst.rank - 1] = lst; 
    } 

    getDegree(){ 
    //this.degreeService.getDegree().then(deg => this.currDeg = deg) 
    this.currDeg = this.degreeService.getDegree(); 
    } 

    ngOnInit(){ 
    this.getDegree(); 
    } 
} 
+0

Что именно означает «* объект всегда возвращается как« неопределенный »*« означает? Когда вы получаете к нему доступ (слишком поздно)? Вам не хватает приложения для области? – Bergi

ответ

0

Я не знаю, как вы используете currDeg в шаблоне, но с обещаниями, все асинхронно. Таким образом, соответствующий объект будет не определен в начале, так как он будет установлен позже (когда обещание будет разрешено). И это, даже если обещание прямо разрешено с Promise.resolve.

export class DegreeService{ 
    getDegree(){ 
    return Promise.resolve(SAMPLE); 
    } 
} 

@Component({ 
    selector: 'my-app', 
    providers: [DegreeService], 
    templateUrl: 'src/app.html' 
}) 
export class App { 
    constructor(private degreeService:DegreeService) { 
    } 

    getDegree(){ 
    this.degreeService.getDegree().then(deg => { 
     this.currDeg = deg; 
     console.log('this.currDeg = ' + this.currDeg); // <------ 
    }); 
    } 

    ngOnInit(){ 
    this.getDegree(); 
    } 
} 

См. Этот plunkr: https://plnkr.co/edit/1fxE0okyMNj2JktURY4w?p=preview.

+0

Спасибо! Вы были правы, что это был шаблонный вопрос. Даже при прямом разрешении с локальным объектом степени, шаблон пытался получить доступ к currDeg слишком рано, и там ничего не было. Проблема решена путем инициализации currDeg для объекта пустой степени. –

Смежные вопросы