如何使用 react-dropzone 读取文件内容?

IT技术 javascript node.js reactjs react-dropzone
2021-05-20 14:28:08

我正在尝试了解有关为即将到来的项目处理文件的更多信息。当 onDrop 碰巧更改我正在上传的文件的内容时,我可以使用 react-dropzone 运行一个函数吗?例如,如果我要上传一个 Word 文档,上面写着“大家好”,我该如何将内容更改为“嗨,尼克博士”?

在尝试进行更改之前,我曾尝试使用 filereader api 访问数据。我尝试在 async 函数的大括号打开后立即使用 filereader,但无法使其正常工作。

import React from 'react';
import Dropzone from 'react-dropzone';
import { graphql } from 'react-apollo';
import gql from 'graphql-tag';

const FileUpload = ({
    children, disableClick, channelId, mutate, style = {},
}) => (
    <Dropzone
        style={style}
        className="ignore"
        onDrop={async ([file]) => {
            const response = await mutate({
                variables: {
                    channelId,
                    file,
                },
            });
            console.log(response);
        }}
        disableClick={disableClick}
    >
        {children}
    </Dropzone>
);

const createFileMessageMutation = gql`
  mutation($channelId: Int!, $file: File) {
    createMessage(channelId: $channelId, file: $file)
  }
`;

export default graphql(createFileMessageMutation)(FileUpload);

非常感谢有关如何访问和修改文件内容的任何想法!谢谢。

1个回答
onDrop={async ([file]) => {
  var reader = new FileReader();
  reader.onload = function(e) {
    var contents = e.target.result;
    displayContents(contents);
  };
  reader.readAsText(file);
}}

您可以在前端做的是读取文件内容并显示它,所有对文件内容的操作都应该在服务器端完成。使用 ajax 将文件推送到服务器,其中包含要更改的信息列表,例如在 nodeJS 中使用fs = require('fs')以进行文件修改。

也请访问这篇文章,我看到人们为您的问题提供了一些解决方案:

是否可以仅使用 JavaScript 将数据写入文件?

这是从上面的链接中提取的小提琴:http : //jsfiddle.net/o4rhg1xe/1/

总之,您可以使用我提供的代码读取文本文件内容,然后使用链接中的方法创建包含您想要的内容的 Blob 对象,并且浏览器可以下载此类文件,(参见小提琴)

仍然在我看来,文件修改应该移到后端,因为我看不到任何用例可以在前端进行修改。