首页 > 解决方案 > 使用 .filter 从带有 react/javascript 的对象数组中删除一个项目

问题描述

我正在使用 javascript 的 .filter 函数通过它在 TypeMp3List 中的 ID 从这个对象数组中删除一个元素。格式是这样的:

在此处输入图像描述

在删除例如 MP3 时,我想要在执行过滤器后得到的格式ID:33390是这样的:

在此处输入图像描述

这是我到目前为止构建的代码:

  showDeleteConfirmation(value, id, index, thisHandler) {
    confirm({
      title: 'Voulez vous supprimer cette audio ?',
      content: '',
      okText: 'Oui, je confirme',
      okType: 'danger',
      cancelText: 'Non',
      onOk() {
       deleteMp3Request(id);
       var { extraitMP3 } = thisHandler.state;

        var array = [];
        for (var key in extraitMP3) {
          array.push(extraitMP3[key]);
        }
        console.log('array',array)

        const result = array.map(d => ({ 
          ...d, 
          TypeMp3List: 
              Object.fromEntries(
                Object.entries(d.TypeMp3List).filter(index => index !== id)
              ) 
        }))
        console.log('result',result)


       thisHandler.setState({result: result})
       NotificationManager.success("le fichier audio est supprimé avec succès !", "");
     },
     onCancel() {
     },
    });  
  }

问题是在映射和过滤之后console.log(result)给了我相同的结果console.log(array)。看起来映射和过滤有问题,不知道到底是什么。任何帮助,将不胜感激。

标签: javascriptarraysreactjsobjectecmascript-6

解决方案


因为您使用Object.entries- 这将返回一个二维数组(例如包含数组的数组),并且在您的内部filter您正在检查每个数组是否等于一个数字。它不是。你想访问这个数组的第一个元素 - 所以要么有点解构:

Object.entries(d.TypeMp3List).filter(([index]) => index !== id)

或更详细的数组表示法:

Object.entries(d.TypeMp3List).filter(index => index[0] !== id)

推荐阅读