angular - typescript : error TS2740: Type '{}' is missing the following properties from type 'Product[]' : length, 弹出、推送、连接等 26 个

标签 angular firebase observable switchmap

使用 Angular 4,我从 observable 中的 firebase db 获取数组列表。如何将 observable 的类型更改为数组,反之亦然以使其工作?

我写的没有不同的功能。我正在使用一个内置函数 switchMap,在其中分配一个 Products 数组。我无法弄清楚如何将可观察的 switchMap 更改为数组可观察。

constructor(
    route:ActivatedRoute,
    productService: ProductService ) { 
      productService
        .getAll()
        .switchMap(products => {
      //getting compile error at below line for this.products
          this.products = products;
          return route.queryParamMap;
        })
        .subscribe(params => {
          this.category = params.get('category');
          this.filteredProducts = (this.category) ? 
            this.products.filter(p => p.category === this.category) :
            this.products;
    });
  }

switchMap observable 一次返回一项的结果,这里有一个数组列表。我如何使它工作。

最佳答案

我想到了。 :)
我更改了 中方法的返回类型product.service.ts 作为 可观察的产品数组 .

 getAll(): Observable<Product[]>{
 return this.db.list('/products');//to get list of all products
}
 get(productId): Observable<Product[]>{
 return this.db.object('/product/' + productId);
}

关于angular - typescript : error TS2740: Type '{}' is missing the following properties from type 'Product[]' : length, 弹出、推送、连接等 26 个,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57214944/

相关文章:

angular - Rxjs 可观察间隔和 Angular2 HTTP : wait for response

angular - 无法读取 angular2 中 null 的属性 'navigate'

node.js - 找不到模块 'angular2/angular2'

forms - 如果字段为空, Angular 形式禁用提交按钮

android - 如何使用 Jetpack Compose UI 在 Android 上正确跟踪屏幕 View ?

Firebase 和 Google OAuth 同意屏幕

angular - 如何将 Observable 数组属性加载为 Angular Material Table 数据源?

angular - 将数据发送到 TemplateRef MatDialog

ios - swift iOS : ImageUrl in Firebase database

rx-java - RxJava Observable 基于内容的缓冲区