6

このエラー が発生しています null のプロパティ 'filter' を読み取れません

angular 2でフィルターを適用すると、コードは次のとおりです

http://plnkr.co/edit/K46jJsnmHiONuqIsnuzW?p=preview

import {Pipe} from 'angular2/core';

@Pipe({
  name: 'sortByName',
  pure: false,
})
export class SortByNamePipe {

  transform (value, [queryString]) {
    // console.log(value, queryString);
    return value.filter((student)=>new RegExp(queryString).test(student.name))
    // return value;
  }
}
4

1 に答える 1

14

It's because you have data as input that are loaded asynchronously using an HTTP request.

You need to check this before being able to apply the filter:

export class SortByNamePipe {
  transform (value, [queryString]) {
    if (value==null) {
      return null;
    }

    return value.filter((student)=>new RegExp(queryString).test(student.name))
    // return value;
  }
}
于 2016-02-11T10:43:32.743 に答える