无法读取未定义 angular 的 属性 7

cannot read property of undefined angular 7

在我的组件中添加服务时,我在开发工具控制台收到很多错误,但代码仍然有效,但我想摆脱这些错误

这是服务:

 getPagesData(pageSlug: string): Observable<any[]> {
    return this._http.get<any[]>(`${environment.apiUrl}wp/v2/pages/?slug=${pageSlug}`);
  }

这是组件:

import { Component, OnInit } from '@angular/core';
import { DataService } from 'src/app/services/data.service';

@Component({
  selector: 'app-membership',
  templateUrl: './membership.page.html',
  styleUrls: ['./membership.page.scss'],
})
export class MembershipPage implements OnInit {


  public pageContent: any = {};
  public content: string;

  constructor(
    private _data: DataService
  ) { }

  ngOnInit() {
    this._data.getPagesData('memberships')
      .subscribe(
        page => this.pageContent = page[0]
      )
  }

  getContent(): string {
    return this.pageContent.content.rendered.replace(/\[(.+?)\]/g, "");
  }

}

导致错误的原因是 getContent() 方法!它说 .rendered 是未定义的 属性 但它在 API 上定义!

我搜索了那个问题,我发现大部分解决方案都是关于在 HTML 模板中使用符号 ?,但我不能在组件本身。

是的,您不能在组件本身中使用 ? Elvis(安全导航)运算符,因为它专为视图部分设计。

但是你也可以在组件中添加一些检查以避免像 -

这样的错误
getContent(): string {
    const dataToReturn = this.pageContent && this.pageContent.content && this.pageContent.content.rendered.replace(/\[(.+?)\]/g, "");
    return dataToReturn
  }

.rendered is an undefined property

另外,这个错误可能会导致你定义了 pageContent = {} so on {} neither content nor rendered exist ,可能这也是存在这样的原因错误。

Angular 建议在使用前对您的数据进行强类型转换。

如果您在 HTML/template 中调用 getContent(),您很可能可以通过以下任一方式避免此错误:

最初制作 pageContent null 并使用 *ngIf 仅在异步解析后显示内容:

分量:

public pageContent: any = null;

模板:

<div *ngIf="pageContent">{{getContent()}}</div>

或者你可以改为使用 RxJS 操作符,例如 map()async 管道:

分量:

import { Component, OnInit } from '@angular/core';
import { DataService } from 'src/app/services/data.service';
import { Observable } from 'rxjs';
import { map } from 'rxjs/operators';

@Component({
  selector: 'app-membership',
  templateUrl: './membership.page.html',
  styleUrls: ['./membership.page.scss'],
})
export class MembershipPage implements OnInit {
  public pageContent: Observable<string>;
  public content: string;

  constructor(private _data: DataService) { }

  ngOnInit() {
    this.pageContent = this._data.getPagesData('memberships')
      .pipe(
        map(page => page[0].content.rendered.replace(/\[(.+?)\]/g, ""))
      );
  }
}

模板:

<div>{{pageContent | async}}</div>

也就是说,您可能应该进行额外的检查以确保每个子 属性 在访问它之前可用,但通常这种类型的错误是因为您试图在它们具有之前访问内容已解决。

希望对您有所帮助!