JokerRush 2019-09-22 11:56 采纳率: 0%
浏览 1065

angular v8.0+ subscribe() 内无法给参数赋值

环境版本:

  • Angular CLI: 8.3.4
  • Node: 10.16.3
  • Angular: 8.2.6
    ***
    代码如下:
    *-server.service.ts
import { Injectable } from '@angular/core';
import { HttpClient, HttpHeaders } from '@angular/common/http';
import { catchError, map, tap } from 'rxjs/operators';
// import 'rxjs/add/operator/map'; // 引入无效

@Injectable({
  providedIn: 'root'
})

export class NaverServerService {

  constructor(private http: HttpClient) { }

  // 获取 资讯 分类、url、flag
  getNewsType() {
    return this.http.get('../../assets/data/newsType.json')
        .pipe(map((res: Response) => res.json())
    );
  }
}

*.component.ts

import { Component, OnInit } from '@angular/core';
import { NaverServerService } from '../_servers/naver-server.service';

@Component({
  selector: 'app-navbar',
  templateUrl: './navbar.component.html',
  styleUrls: ['./navbar.component.css'],
  providers: [NaverServerService]
})

export class NavbarComponent implements OnInit {

  newsTypes: any = [];

  constructor(
    private navServer: NaverServerService) {
  }

  ngOnInit() {
    // 调用 NaverServerService
    this.navServer.getNewsTypes().subscribe(
      (data) => this.newsTypes = data
    );
    console.log(this.newsTypes);
  }
}


运行无异常,但是this.newsTypes赋值无效。


运行效果如下图:

图片说明

图片说明



如果,打印结果,可以看到数据结果。



图片说明

图片说明



如果,赋值,什么也看不见。

求解,该如何赋值?

  • 写回答

2条回答 默认 最新

  • zqbnqsdsmd 2019-09-23 13:13
    关注
    评论

报告相同问题?

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站