使用multer刷新文件上传React app

时间:2018-03-14 14:45:03

标签: node.js reactjs express multer

更新

这种情况正在发生,因为Creact React App附带了热重新加载。 相关问题: https://github.com/expressjs/multer/issues/566

https://github.com/facebook/create-react-app/issues/4095

我正在尝试使用Nodejs,Express,Multer和React来学习文件上传。我实现了上传文件。有一个问题我很难,但并不总是,但大多数时候整个应用程序上传后刷新。这是相关的代码。

我的简单表格

<form onSubmit={this.handleFormSubmit}>
                <input
                    type="file"
                    id="file"
                    onChange={this.handleFileChange}
                />
            <button type="submit">Submit</button>
        </form>

handleFileChange和handleFormSubmit

handleFormSubmit = () => {
    const formData = new FormData();
    formData.append( "file", this.state.file );
    axios.post( "/api/upload", formData );
}

handleFileChange = ( e ) => {
    this.setState( { file: e.target.files[ 0 ] } );
}

相关快递路线代码

const express = require( "express" );
const multer = require( "multer" );
const storage = multer.diskStorage( {
    destination( req, file, cb ) {
        cb( null, "client/public/images" );
    },
    filename( req, file, cb ) {
        cb( null, `${ Date.now() }-${ file.originalname }` );
    },
} );

const upload = multer( { storage } );

router.post( "/upload", upload.single( "file" ), ( req, res ) => {
    res.send();
} );

我搜索了一下但没有运气。我见过this post。在看到这个之前,我已经尝试过event.preventDefault()。此外,我尝试过许多事情,例如直接使用onChange()上传而不设置状态,然后使用onSubmit()处理它。在简化代码之前(比如直接在handleFormSubmit中发布)我试图通过Redux操作来做到这一点,但为了调试目的,我把它移到了这里。

2 个答案:

答案 0 :(得分:0)

你正在使用

<button type="submit">Submit</button>

这就是刷新的原因

所以这样做

<button onClick={this.handleFormSubmit}>Submit</button>

答案 1 :(得分:0)

这是第一个例子here

Web