Angular 2 [(ngModel)] не работает

NET Core и Angular 2 приложения. Я успешно связался с контроллером веб-API и могу войти в объект в консоли.

Однако, когда я пытаюсь зарегистрировать компонент в файле ts или получить доступ к его свойствам с помощью [(ngModel)], у меня не получается.

Спасибо за любой совет, как успешно получить доступ к свойствам объекта в HTML. Вот мой код:

user.service.ts

    import { Injectable } from '@angular/core';
    import { Observable } from 'rxjs/Rx';
    import { Http, Response, Headers } from '@angular/http';
    import { APP_CONFIG, IAppConfig } from './app.config';
    import { Component, Inject } from '@angular/core';

    @Injectable()
    export class UserService {

        constructor(private http: Http, @Inject(APP_CONFIG) private config: IAppConfig) { }

//SUCCESSFULLY LOG JSON OBJECT HERE
        public getCurrentUser = (): Observable<any> => {
            return this.http
                .post(this.config.apiEndpoint + "currentUser")
                .map((response: Response) => <any>response.json())
                .do(x => console.log(x));
        }
    }

home.component.ts

import { Component, OnInit } from '@angular/core';
import { UserService } from '../../user.service';
import { AngUser } from '../../ang-user';
import { Observable } from 'rxjs/Rx';

@Component({
    selector: 'home-page',
    templateUrl: './app/components/home/home.component.html',
    providers: [UserService]
})

export class HomeComponent implements OnInit {
    constructor(public userService: UserServicer) { }
    public value: any;

    showObject(): void {
          console.log(this.value.id);
          console.log(this.value.userName);
    }

    ngOnInit(): void {
      this.userService.getCurrentUser()
            .subscribe(data => this.value = data,
           error => console.log(error),
           () => console.log('Get User complete!'));

       this.showObject();
    }



} 

home.component.html

<!-- THIS FAILS TO SHOW ANYTHING -->
        My Values: <ul>
            <li [(ngModel)]="value">
                <span>{{value.id}} {{value.userName}}</span>
            </li>
        </ul>

2 ответа

Решение

Удалить [(ngModel)]="value" от li

 <li >
   <span>{{value.id}} {{value.userName}}</span>
 </li>
<!-- if u get only one object -->
<!--this.value = [{ id: 1, name: 'pbt1' }];-->

My Values: <ul>
    <li>
        <span>{{value[0].id}} {{value[0].name}}</span>
        <input [(ngModel)]="value[0].name" />

    </li>
</ul>

<!-- if u get more than one  -->
<!--this.value = [{ id: 1, name: 'pbt1' }, { id: 2, name: 'pbt2' },{ id: 3, name: 'pbt3' }];-->
My Values: <ul >
    <li *ngFor="let v of value">
        <span>{{v.id}} {{v.name}}</span>
        <input [(ngModel)]="v.name" />
    </li>
</ul>
Другие вопросы по тегам