【问题标题】:Can not access objects key value pairs无法访问对象键值对
【发布时间】:2019-04-03 19:28:50
【问题描述】:

我通过 FormData 从我的 VueJS 前端发送图像到我的 Express 服务器,以将它们存储在带有 gridfs-stream 和 mongoose 的 Mongo DB 中。图像对象到达服务器,但我不知道如何访问它的键值对。

我跑的时候

let part = req.files
for (const prop in part) {
   console.log('part.${prop} = ${part[prop]}')
}

我得到了这个输出:

part.files[0] = [object Object]
part.files[1] = [object Object]

但是当我尝试访问 part.files[0] 时,我收到了这个错误:

TypeError: Cannot read property '0' of undefined

这是对象的结构:

{ 'files[0]':
 { data: <Buffer ff d8 ff e0 00 10 4a 46 49 46 00 01 01 01 00 48 00 48 00 00 ff db 00 43 00 08 06 06 07 06 05 08 07 07 07 09 09 08 0a 0c 14 0d 0c 0b 0b 0c 19 12 13 0f ... >,
 name: 'e0ZnCwP.jpg',
 encoding: '7bit',
 mimetype: 'image/jpeg',
 truncated: false,
 size: 259454 },
'files[1]':
 { data: <Buffer ff d8 ff e0 00 10 4a 46 49 46 00 01 01 00 00 48 00 48 00 00 ff c0 00 11 08 06 40 04 c8 03 01 22 00 02 11 01 03 11 01 ff c4 00 1f 00 00 01 05 01 01 01 ... >,
 name: 'Me.jpeg',
 encoding: '7bit',
 mimetype: 'image/jpeg',
 truncated: false,
 size: 108021 } }

提前致谢!

【问题讨论】:

    标签: javascript mongodb express mongoose gridfs-stream


    【解决方案1】:

    object.files[0] 读取名为files 的属性的第一项,假定它是一个数组。你的对象没有这个属性,有字符串键files[0]files[1]等。这可能是一个错误,如果不是,你可以间接引用这些道具object["files[0]"]object["files[1]"],@ 987654327@等

    【讨论】:

      【解决方案2】:

      您有两种 JSON 类型: #1

      var part = {
      files : { 
          { 
              data: <Buffer ff d8 ff e0 00 10 4a 46 49 46 00 01 01 01 00 48 00 48 00 00 ff db 00 43 00 08 06 06 07 06 05 08 07 07 07 09 09 08 0a 0c 14 0d 0c 0b 0b 0c 19 12 13 0f ... >,
               name: 'e0ZnCwP.jpg',
               encoding: '7bit',
               mimetype: 'image/jpeg',
               truncated: false,
               size: 259454 
          }, { 
              data: <Buffer ff d8 ff e0 00 10 4a 46 49 46 00 01 01 00 00 48 00 48 00 00 ff c0 00 11 08 06 40 04 c8 03 01 22 00 02 11 01 03 11 01 ff c4 00 1f 00 00 01 05 01 01 01 ... >,
               name: 'Me.jpeg',
               encoding: '7bit',
               mimetype: 'image/jpeg',
               truncated: false,
               size: 108021 
          } 
      }
      

      或者你得到的那个: #2

      var part = { 
          'files[0]': { 
          data: <Buffer ff d8 ff e0 00 10 4a 46 49 46 00 01 01 01 00 48 00 48 00 00 ff db 00 43 00 08 06 06 07 06 05 08 07 07 07 09 09 08 0a 0c 14 0d 0c 0b 0b 0c 19 12 13 0f ... >,
           name: 'e0ZnCwP.jpg',
           encoding: '7bit',
           mimetype: 'image/jpeg',
           truncated: false,
           size: 259454 
      }, 
      'files[1]': { 
          data: <Buffer ff d8 ff e0 00 10 4a 46 49 46 00 01 01 00 00 48 00 48 00 00 ff c0 00 11 08 06 40 04 c8 03 01 22 00 02 11 01 03 11 01 ff c4 00 1f 00 00 01 05 01 01 01 ... >,
           name: 'Me.jpeg',
           encoding: '7bit',
           mimetype: 'image/jpeg',
           truncated: false,
           size: 108021 
      } 
      

      它们之间的区别在于 #1 files 变量是一个数组,因此您可以像这样访问它们:part.files[i]。 但是在 #2(您的情况)中,您获得了数组键/值,因此您可以通过 part['files['+i+']'] 访问您的文件。

      【讨论】:

        猜你喜欢
        • 2019-10-07
        • 2019-04-15
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2020-10-10
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多