首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在http响应的属性值之后未定义角度变量4

在http响应的属性值之后未定义角度变量4
EN

Stack Overflow用户
提问于 2018-09-28 03:15:45
回答 1查看 38关注 0票数 0

我是angular的新手,我有以下问题

将响应值分配给我的服务的变量时,该变量在合唱控制台中显示为未定义

但在subscribe方法http中,该变量具有响应的赋值。

我不明白问题所在

代码语言:javascript
复制
@Injectable() 
export class ControlService {

    permissao: string;

    constructor(
                private httpConnection: HttpConnection,
                private http: Http){}


    getControl(){
        if(localStorage.papel){

            this.buscar('desconto', 'todos');

            console.log('Permissão: ' + this.permissao);

    }

    buscar(desconto : string, todos : string){

        return this.http.get('http://localhost:8080' + "/" + aplicacao + "/" + nome)
            .subscribe((response) => {this.permissao = response.text(); console.log(this.permissao)});
    }   
}

console.log inside busca方法在google chrome控制台中显示该值,但是getControl方法中的控制台将permissao变量的值显示为未定义

EN

回答 1

Stack Overflow用户

发布于 2018-09-28 03:20:20

this.buscar是异步操作,getControl内部的console.log语句是同步调用的。所以它的调用紧跟在this.buscar('desconto','todos')行之后。但是,与此同时,buscar订阅块尚未执行,仍在等待get调用得到解决。因此,你变得不确定了。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52543726

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档