2016-09-18 10 views
1

カントアクセス深いレベルのオブジェクト

{ 
"files": [ ], 
"posts": [ 
    { 
     "content": "Dies ist ein Test-Posting, das zum Projekt 2 gehört.", 
     "id": 2, 
     "name": "Beispiel Post 2", 
     "timestamp": "Wed, 10 Aug 2016 19:52:09 GMT" 
    } 
], 
"project": { 
    "id": 2, 
    "info": "Dies ist der Text für das Beispiel Projekt 2", 
    "name": "Beispiel Projekt 2", 
    "timestamp": "Wed, 10 Aug 2016 19:50:59 GMT" 
    } 
} 

そのコンポーネント変数に格納し、今私は私のテンプレートにアクセスしたいです。私はこのような何かをしようとしました:

{{project.project.id}} 

これは動作しません。私はすでにこのような解決策を試してみた

Object { files: Array[0], posts: Array[1], project: Object } 

:オブジェクトは、そのように保存されているiteration a json object on Ngfor in angular 2それ文句を言わないの助け。

は、相続人は私が得た例外:詳細については
Uncaught (in promise): Error: Error in ./ProjectDetailComponent class ProjectDetailComponent - inline template:0:4 caused by: self.context.project is undefined

を、ここでは、ファイルは次のとおりです。

コンポーネント:

@Component({ 
    selector: 'app-project-detail', 
    templateUrl: './project-detail.component.html', 
    styleUrls: ['./project-detail.component.sass'] 
}) 
    export class ProjectDetailComponent implements OnInit { 
    private project; 
    private errorMessage; 

    constructor(private route: ActivatedRoute, 
       private router: Router, 
       private projectService: ProjectsService) { 
    } 

    ngOnInit() { 
     this.route.params.forEach((params: Params) => { 
      let id = +params['id']; 
      this.projectService.getProjects(id).subscribe(
       function (project) { 
        this.project = project; 
       }, 
       error => this.errorMessage = <any>error 
      ); 
     }); 
    } 

} 

はサービス:

@Injectable() 
export class ProjectsService { 

    constructor(private http: Http) {} 

    private projectsUrl = 'http://localhost:2000/api/projects/'; 

    getProjects(id?: number): Observable<any>{ 
     if(id){ 
      return this.http.get(this.projectsUrl + ""+id) 
       .map(this.extractData) 
       .catch(this.handleError); 
     } else { 
      return this.http.get(this.projectsUrl) 
       .map(this.extractData) 
       .catch(this.handleError); 
     } 


    } 

    private extractData(res: Response) { 
     let body = res.json(); 
     return body; 
    } 
    private handleError (error: any) { 
     // In a real world app, we might use a remote logging infrastructure 
     // We'd also dig deeper into the error to get a better message 
     let errMsg = (error.message) ? error.message : 
      error.status ? `${error.status} - ${error.statusText}` : 'Server error'; 
     console.error(errMsg); // log to console instead 
     return Observable.throw(errMsg); 
    } 
} 

私は感謝します助けて!

+0

でそれを使用し、残念ながら;-) –

答えて

1

値はあなたの物がどこに割り当てられていません。

ngOnInit() { 
    this.route.params.forEach((params: Params) => { 
     let id = +params['id']; 
     this.projectService.getProjects(id).subscribe(

      // function (project) { 
      // should be 
      (project) => {    // <<<<=== change 
       this.project = project; 
      }, 
      error => this.errorMessage = <any>error 
     ); 
    }); 
} 

と「それは動作しません」

{{project?.project?.id}} 
+0

なしに何が起こっているかの非常に詳細な説明ではありません。エルヴィスのオペレータは、変数が定義されているかどうかをチェックするだけだと思います。私が間違っていれば私を訂正してください。 – Lelsoos

+0

残りの評価を続ける前に '?.'の左の式がヌルかどうかをチェックします。問題が何であるかについての詳細な説明がなくても、これが問題かどうかを判断するのは難しいです。 –

+0

私はこの問題がそうであるように簡単だと思います。変数にオブジェクトとして格納された応答を持っています。今私はその変数をテンプレート内で補間したいが、うまくいきません。レンダリングされたテンプレートには何も表示されません。 – Lelsoos

関連する問題