javascript - Angular 2 AsynPipe 不与 Observable 一起工作

标签 javascript angular reactive-programming rxjs observable

我收到以下错误:

EXCEPTION: Cannot find a differ supporting object '[object Object]' in [files | async in Images@1:9]

这是模板的相关部分:

<img *ngFor="#file of files | async" [src]="file.path">

这是我的代码:

export class Images {
  public files: any; 
  public currentPage: number = 0;
  private _rawFiles: any;

  constructor(public imagesData: ImagesData) {
    this.imagesData = imagesData;  
    this._rawFiles = this.imagesData.getData()
        .flatMap(data => Rx.Observable.fromArray(data.files));
    this.nextPage();
  }

  nextPage() {
    let imagesPerPage = 10;
    this.currentPage += 1;
    this.files = this._rawFiles
                    .skip((this.currentPage - 1) * imagesPerPage)
                    .take(imagesPerPage);
    console.log("this.files:", this.files);                
  }
}

最后的 console.log 显示它是一个可观察的:

last console.log

this.imagesData.getData() 从 Angular 的 Http 服务返回一个常规的 RxJS observable,那么为什么异步管道不能使用它呢?也许我使用 flatMap() 的方式是错误的,它搞砸了?

如果我尝试像这样订阅这个 observable:

this.files = this._rawFiles
                .skip((this.currentPage - 1) * imagesPerPage)
                .take(imagesPerPage)
                .subscribe(file => {
                  console.log("file:", file);
                });

它按预期打印对象列表:

enter image description here

最佳答案

尝试使用 Observable<File[]>相反:

this.files = this._rawFiles
         .skip((this.currentPage - 1) * imagesPerPage)
         .take(imagesPerPage)
         .map(file => [file])
         .startWith([])
         .scan((acc,value) => acc.concat(value))

这应该不需要手动代码 subscribe并且应该与您当前的模板完美配合。

我在 this blog post. 中做了非常相似的事情

关于javascript - Angular 2 AsynPipe 不与 Observable 一起工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36686465/

相关文章:

javascript - Alfresco:工作流程脚本失败取决于文件夹级别

Wordpress 中的 JavaScript - 无法调用函数

angular - ngOnDestroy 中的 RxJS "unsubsribe"方法处理资源的速度不够快

java - RxJava 中 REAL 背压的最佳实现

JavaScript 排序对象

angular - @Output 从指令发出值到父组件 Angular 4

angular - 人工审核 - 有些漏洞需要您注意才能解决

c# - Reactive Extensions 中的 SequenceEqual 如何工作

reactive-programming - 使用 Reactive 对 Observable 的某些部分求和

php - 如何在 Javascript 中使用 PHP 的变音符号