ximalangyashan 2022-10-22 21:14 采纳率: 98.9%
浏览 33
已结题

react数组代码有问题

react数组代码有问题

代码如下

let fileMessage = [
    {
      code: 'file-invalid-type',
      message: 'Select the correct file type',
    },
    {
      code: 'file-too-large',
      message: 'Total File Size is limited to maximum 25MB',
    },
  ];
 
let fileRejections = [
    {
      errors: [
        { code: 'file-invalid-type', message: 'File type must be one of image/*' },
        { code: 'file-too-large', message: 'File is larger than 26214400 bytes' }  // 有可能是这行数据
      ],
    },
  ];
 
const fileRejectionItems = fileRejections.map(({ file, errors }) => (
    <div key={file.path}>
      <>
        {errors.map((e) => (
          <ErrorMsg
            key={e.code}
            className={classes.errorMsg}
            type='error'
            label={fileMessage.find((i) => (i.code === e.code ? i : e.message)).message}
          />
        ))}
      </>
    
));

希望根据code相等,return fileMessage 里对应的message,但是始终return这个message: 'Select the correct file type'

  • 写回答

2条回答 默认 最新

  • CSDN专家-showbo 2022-10-22 21:17
    关注

    逻辑有问题,
    label={fileMessage.find((i) => (i.code === e.code ? i : e.message)).message}
    粉红色这句find一项时,返回值就是等级于true的了,不管code是否匹配,所以直接返回了第一项的内容

    改下面这样,当fileMessage找不到code匹配的项,再用e这个变量中的message
    label = { (fileMessage.find(i => i.code === e.code) || e).message }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月30日
  • 已采纳回答 10月22日
  • 创建了问题 10月22日

悬赏问题

  • ¥15 GD32 SPI通信时我从机原样返回收到的数据怎么弄?
  • ¥15 phython读取excel表格报错 ^7个 SyntaxError: invalid syntax 语句报错
  • ¥20 @microsoft/fetch-event-source 流式响应问题
  • ¥15 ogg dd trandata 报错
  • ¥15 高缺失率数据如何选择填充方式
  • ¥50 potsgresql15备份问题
  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?