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
    关注
    评论

报告相同问题?

悬赏问题

  • ¥20 蓝牙耳机怎么查看日志
  • ¥15 Fluent齿轮搅油
  • ¥15 八爪鱼爬数据为什么自己停了
  • ¥15 交替优化波束形成和ris反射角使保密速率最大化
  • ¥15 树莓派与pix飞控通信
  • ¥15 自动转发微信群信息到另外一个微信群
  • ¥15 outlook无法配置成功
  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏