首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >无法读取未定义的属性“”toString“”

无法读取未定义的属性“”toString“”
EN

Stack Overflow用户
提问于 2018-01-12 13:14:24
回答 2查看 12.8K关注 0票数 3

data-filter.pipe.ts

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import { Pipe, PipeTransform } from '@angular/core';

@Pipe({
  name: 'dataFilter'
})
export class DataFilterPipe implements PipeTransform {

  transform(array: any[], query: string): any {

    if (!query || query === '') {
      return array;
    }

    let filtered = [];
    array.forEach(function (element) {
      let isAdded = false;
      Object.keys(element).forEach(function (key, index) {
        if (!isAdded && element[key].toString().toLowerCase().includes(query.toLowerCase())) {
          filtered.push(element);
          isAdded = true;
        }
      });
    });

    return filtered;
  }

}

在.html中

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<table class="bordered table-bordered" [mfData]="users | dataFilter : filterQuery" #mf="mfDataTable"
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-01-12 13:17:56

表示某个关键element[key]的值为undefined。您需要再添加一项检查,以验证真实性

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!isAdded && element[key] && element[key].toString()...
// ---------^^^^^^^^^^^^---------------------------
票数 1
EN

Stack Overflow用户

发布于 2018-01-12 13:23:31

我在代码中看到了两件事:

1-每当您使用对象键时,请确保使用hasOwnProperty测试预期的键(除非您不想这样做

2-在你发布的代码中只有一次toString()用法,从错误中,你确切地知道它是什么,不能在undefined上调用函数,因此element[key]是未定义的。注意,键存在但值不存在,你可以用很多方法来解决这个问题,就像@sauren建议的那样,你可以在if语句中添加它,或者确保在调用函数之前将它设置为空字符串,或者任何你认为合适的东西。但是想法是一样的,在使用它来调用函数之前,请确保该值没有未定义。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48227048

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文