Angular 新手,无法从组件外部访问变量

Posted

技术标签:

【中文标题】Angular 新手,无法从组件外部访问变量【英文标题】:New to angular, cant wrap my head around accessing variables from outside of a component 【发布时间】:2019-05-02 05:02:51 【问题描述】:

好的,让我尽量总结一下。我是 Angular 的新手,已经进行了相当彻底的搜索,但似乎找不到我的问题的答案:

现在我有: Api.Service.ts

import  Injectable  from '@angular/core';
import  HttpClient, HttpHeaders  from '@angular/common/http';
import  Observable  from 'rxjs';


const httpOptions = 
  headers: new HttpHeaders(
    'Accept': 'application/json',
    'Content-Type': 'application/json'
  )
;

@Injectable( providedIn: 'root' )

export class TokenService 
  private tokenUrl = 'http://urlofapi/auth/token';

  constructor(private http: HttpClient)  

  addToken(): Observable<any> 
    return this.http.post(this.tokenUrl, httpOptions);
  


api.component.ts

import  Component, OnInit  from '@angular/core';
import  TokenService  from '../api.service';

@Component(
  selector: 'app-api',
  templateUrl: './api.component.html',
  styleUrls: ['./api.component.scss']
)

export class ApiComponent implements OnInit 

  constructor(private tokenService: TokenService)  

  ngOnInit() 
    this.tokenService.addToken().subscribe((data => 
      this.data = data;
      const finalToken = this.data['token'];

      console.log(finalToken);
    );

  

令牌正在通过 POST 握手从 API 返回。它以以下格式返回:


  "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJVVUlEIjoiYTM3YWFmNzAtZjU0Yy00MGMwLWEwZGUtOTE4NTBkNjY1ODI2IiwiZGV2aWNlSWQiOiIxMjIzMzMiLCJleHBpcmVzQXQiOiIyMDE4LTExLTI5VDIwOjI4OjM3WiJ9.VcTt_TJWFA58iBCDS0JnTAJkH9EzU15QES9k0vI84Ic"

我正在将令牌记录到控制台,所以我知道它正在定义和接收它。

所以我的问题 我正在获取令牌,它被设置为 finalToken,它被记录到控制台。问题是由于某种原因,该变量对应用程序的其他任何部分都不可见

所以如果我尝试从 ngOnInit() 包装器之外的任何地方调用它,它会以未定义的形式返回。

例如,如果我想通过以下方式在我的 api.component.html 中将其打印到屏幕上:

finalToken

在浏览器中,我得到:
<p _ngcontent-c1=""></p>

没有错误,但它没有拉变量

非常 tl:dr;是否可以使 const finalToken 在全球范围内可用?我需要能够在对 API 的任何其他请求的标头中提交它,但现在我什至无法在它所在组件的 HTML 中访问它

【问题讨论】:

【参考方案1】:

您并不真的希望将其作为变量全局访问 - 将其留在服务中并将其注入您想要的位置(正如您已经在做的那样)。这将允许更好的数据封装。

要在组件 html 中访问它,您需要为其创建一个 public 属性。所以而不是:

ngOnInit() 
    this.tokenService.addToken().subscribe((data => 
      this.data = data;
      const finalToken = this.data['token'];

      console.log(finalToken);
    );

  

这样做:

public finalToken: string = null;
ngOnInit() 
    this.tokenService.addToken().subscribe((data => 
      this.data = data;
      this.finalToken = this.data['token'];

      console.log(finalToken);
    );

  

您的 html finalToken 不需要更改。

【讨论】:

你摇滚!!!我完全迷失在公共部分。这非常有效。谢谢! @DanielStockbridge 很高兴我能帮上忙,你已经非常接近了。 不幸的是,“非常接近”让我把头撞在墙上太久了。踢自己不只是尽快启动堆栈溢出帐户并询问

以上是关于Angular 新手,无法从组件外部访问变量的主要内容,如果未能解决你的问题,请参考以下文章

为啥从内部组件中更改 @Input 变量会导致它无法检测到来自外部组件的新更改?

如何使用 Angular JS 从外部范围访问数组值

从 Angular 组件动态加载外部 javascript 文件

Angular2:观察角度之外的外部变量

Angular2 - 从另一个独立组件调用函数。基本上,从外部组件调用函数

在 C++ 中从外部访问嵌套类