- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用一个名为 react-dropzone 和 React-Redux 的 Node 包模块来允许用户将文件拖到窗口上并显示文件信息。
react-dropzone 组件为我提供了标准 event.dataTransfer.files 中的 FileList .
我遇到的问题是,当我将该 FileList 分派(dispatch)到 Redux 存储时,File 项尚未加载到 FileList 数组中,因此当我分派(dispatch) File 数据时,我只得到 {"preview":"blob:file:///f30eafb8-8a77-4402-9111-379590b4a03f"}
.
如果我将文件项记录到控制台,它们会显示得很好,因为它们的数据在我查看时已加载,但我无法弄清楚如何仅在加载文件信息后发送文件信息。
这是一个示例,说明如果我从 FileList 数组将其中一个文件项记录到控制台,我会看到什么。
{
lastModified: 1473709614000,
lastModifiedDate: Mon Sep 12 2016 12:46:54 GMT-0700 (PDT),
name: "test_image.jpg",
path: "/Users/mitchconquer/Desktop/test_image.jpg",
preview: "blob:file:///0fe69686-125d-464a-a0a8-a42e497d3808",
size: 41805,
type: "image/jpeg",
webkitRelativePath: ""
}
// FileDrop.js
import React, { Component, PropTypes } from 'react';
import { Link } from 'react-router';
import styles from './Home.css';
import Dropzone from 'react-dropzone';
export default class FileDrop extends Component {
static propTypes = {
message: PropTypes.string.isRequired,
setFile: PropTypes.func.isRequired
};
onDrop(files, event) {
console.log({files});
this.props.setFile(files);
}
render() {
return (
<div>
<Dropzone onDropAccepted={this.onDrop.bind(this)} multiple={false} disablePreview={false}>
<div>{this.props.message}</div>
</Dropzone>
</div>
);
}
}
setFile
上面使用的方法
onDrop
方法:
// actions/files.js
export const SET_FILE = 'SET_FILE';
// ACTION CREATORS
function _setFile(file) {
return {
type: SET_FILE,
file
};
}
// ACTION CREATOR CREATORS
export function setFile(file) {
return _setFile(file[0]);
}
// reducers/files.js
import { SET_FILE } from '../actions/files';
export const initialState = [];
export default function files(state = initialState, action = {}) {
switch (action.type) {
case SET_FILE:
const newState = state.slice();
const file = action.file;
newState.push(file);
return newState;
default:
return state;
}
}
最佳答案
对于那些遇到这个问题的人,对我来说,我认为问题在于文件列表中的文件不是我认为的“普通的 JavaScript 对象”,但实际上是文件/Blob。
我不确定细节——如果有人能解释一下,我会很高兴——但我想我知道的是,blob没有像标准JS对象那样的键,所以你不能只是插入它到 Redux 存储,查看我期望的属性的键值对 (lastModified, lastModifiedDate, name, path, preview, size, type, webkitRelativePath
)。
如果您只查看 blob,它们唯一的属性是 preview
因为那是 React Dropzone 在 File/Blob 上专门设置的属性。要查看其他属性,您必须调用 blob 上的每个属性。
这是我下面的解决方案的简化版本。我接受 Filelist 数组,创建一个新对象来设置键值并遍历每个键,并在 newFile
上使用其属性设置它目的。最后我返回那个对象。然后,您可以在商店中设置该对象,它将具有处理文件所需的数据。
onDrop(files) {
const fileBlob = files[0];
const newFile = {};
_fileProperties.forEach(key => {
newFile[key] = fileBlob[key];
});
return newFile;
}
const _fileProperties = [
'lastModified',
'lastModifiedDate',
'name',
'path',
'preview',
'size',
'type',
'webkitRelativePath'
];
关于reactjs - 加载文件项后如何仅从 dataTransfer 调度 FileList,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40252955/
我是一名优秀的程序员,十分优秀!