2017-05-12 4 views
0

저는 지금 당분간이 문제에 시달렸으며 많은 해결책을 시도했습니다.관찰 가능한 구독 내에서 각도 로컬 스코프를 사용할 수 없습니다.

내 구독 정보 내에서 ChangeDetectorRef 또는 NgZone에 액세스 할 수 없어 내 범위를 강제 업데이트합니다.

왜 아무 것도 작동하지 않습니까? HTTP 요청을 수행하는 다른 각도 인식 방법이 있습니까?

로그인 구성 요소

import {ChangeDetectionStrategy, ChangeDetectorRef, Component, NgZone, OnInit} from '@angular/core'; 
import {LoginService} from './login.service'; 
import {Observable} from 'rxjs/Observable'; 

@Component({ 
    selector: 'app-login', 
    templateUrl: './login.component.html', 
    styleUrls: ['./login.component.css'], 
    providers: [LoginService] 
}) 
export class LoginComponent implements OnInit { 
    zone: NgZone; 
    username = ''; 
    password = ''; 
    showerror = false; 
    errormsg = ''; 
    rs = {}; 
    results: any; 


    constructor(private _loginService: LoginService, private ref: ChangeDetectorRef) { 

    } 

    refr = function() { 
     console.log('refresh'); 
     console.log(this.errormsg); // is empty even after HTTP call 
     this.ref.markForCheck(); 
     console.log(this.results); 
    }; 

    login = function() { 
     console.log(this.username, this.password); 

     this._loginService.login(this.username, this.password).subscribe(function (data) { 

      console.log('log me in'); 
      console.log(data); // the correct data is logged here 
      this.errormsg = 'Invalid Username and Password'; // the text is never updated 
      this.zone.run(); // zone has no method run 
      this.ref.markForCheck(); // ref has no method markForCheck 
     }); 

     // this.results = this._loginService.login(this.username, this.password); 
     // this.results.subscribe(rs => this.rs = rs); 
    }; 

    ngOnInit() { 

    } 

} 

로그인 서비스

import {Injectable} from '@angular/core'; 
import {CONFIG} from '../config'; 
import {Http, Response} from '@angular/http'; 
import {Observable} from 'rxjs/Observable'; 
import 'rxjs/add/operator/map'; 
import 'rxjs/add/operator/do'; 
import 'rxjs/add/operator/catch'; 

const loginUrl: string = CONFIG.apiserv + 'api.login.php'; 

@Injectable() 
export class LoginService { 
    private http; 
    constructor(http: Http) { 
     this.http = http; 
    } 

    login = function (username, password): Observable<Response> { 
     console.log('login clicked'); 
     let url = new URLSearchParams(); 
     url.append('username', username); 
     url.append('password', password); 
     const fullurl = loginUrl + '?' + url.toString(); 

     return this.http.get(fullurl) 
      .map((response: Response) => response.json()) 
      .do(data => console.log('All: ' + JSON.stringify(data))) 
      .catch(this.handleError); 
    }; 
    handleError = function (error: Response) { 
     console.log(error); 
     return Observable.throw(error.json().error || 'Server error'); 
    }; 
} 

답변

2

당신이 this을 사용하고 있기 때문에, 당신은 arrow function 사용해야합니다

this._loginService.login(this.username, this.password).subscribe(data => { 

     console.log('log me in'); 
     console.log(data); // the correct data is logged here 
     this.errormsg = 'Invalid Username and Password'; // the text is never updated 
     this.zone.run(); 
     this.ref.markForCheck(); 
    }); 
+0

:) – cgTag

1

this을 새로 계산 된 범위에 바인딩하려면 =>을 사용해야합니다.

this._loginService.login(this.username, this.password).subscribe(data => { 

참조 : https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Functions/Arrow_functions

그렇지 않으면 변수에 this를 할당 할 수 있지만 타이프 라이터 또는 ES6를 사용하는 경우는 필요가 없습니다.

var that = this; 
this._loginService.login(this.username, this.password).subscribe(function (data) { 
    that.zone.run(); 
    ...