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 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?