Подтвердить что ты не робот

Проблема с * ngIf в Angular 2 (TypeScript)

Я использую Angular 2 beta (TypeScript). Я встретил странную проблему. Я пробовал Chrome, Firefox, Opera, все те же результаты.

Когда я нажимаю кнопку "Toggle", она может успешно отображать/скрывать текст "Hello World!".

Когда я отправляю команду из другого браузера с помощью сокета, логическое "шоу" меняет успешный фон, однако текст не отображается/скрывается, что выглядит так, что страница не обновляется.

import {Component, View} from 'angular2/core';
import {bootstrap} from 'angular2/bootstrap';
import {NgIf} from 'angular2/common';

@Component({
    selector: 'app'
})
@View({
    directives: [NgIf],
    template: `
      <button (click)="clicked()">Toggle</button>
      <div>
        <div *ngIf="show">
          <h2>Hello World!</h2>
        </div>
      </div>
    `
})
class App {
    show: boolean = true;

    constructor() {
        Socket.on {
            If (getMessage) {
                this.show = !this.show;
            }
        }
    }

    clicked() {
        this.show = !this.show;
    }
}

bootstrap(App);
4b9b3361

Ответ 1

Я думаю, что это проблема, связанная с зоной. Последний отвечает за уведомление Angular, что ему необходимо обработать обновление.

Этот вопрос может дать вам несколько советов: Просмотр не обновляется при изменении Angular2.

Вы можете попробовать что-то вроде этого:

export class App {
  constructor(ngZone:NgZone) {
    this.ngZone = ngZone;
    Socket.on {
      this.ngZone.run(() =>
        If (getMessage) {
            this.show = !this.show;
        }
      });
    }
  }

  }

Этот вопрос также может быть связан с вашей проблемой: Angular2 изменение дочернего имущества, не обновляющее обновление связанного свойства.

Надеюсь, это поможет вам, Thierry

Ответ 2

Кажется, что код Socket работает вне зоны углов. Inject NgZone и используйте zone.run(...), поэтому Angular, чтобы Angular знал о необходимости обнаружения изменений.

class App {
  show: boolean = true;

  constructor(zone: NgZone) {
    Socket.on {
        if (getMessage) {
            zone.run(() => { this.show = !this.show; });
        }
    }
  }


  clicked() {
    this.show = !this.show;
  }
}