Upload de imagem em react não retorna valores de dados de formulário
Dec 15 2020
Quero obter valores de dados de formulário fazendo upload de imagens.
import React from "react";
import "./styles.css";
import { Upload, Button, Form } from "antd";
export default function App() {
const normFile = (e) => {
const fd = new FormData();
const getFileList = e.fileList.map((i) => {
return fd.append("upload", i.originFileObj);
});
console.log("formadata values", fd);
if (Array.isArray(e)) {
return e;
}
return e && e.fileList;
};
return (
<div className="App">
<div>
<Form name="form" className="form">
<Form.Item
name="upload"
className="upload"
valuePropName="fileList"
getValueFromEvent={normFile}
>
<Upload name="img" listType="picture">
<Button className="btn">upload images</Button>
</Upload>
</Form.Item>
</Form>
</div>
</div>
);
}
Tentando acessar console.log("formadata values", fd);
não consigo nada lá.
Pergunta: Como obter dados de formulário usando meu código?
demo:https://codesandbox.io/s/priceless-flower-82tbe?file=/src/App.js:0-883
Respostas
1 Ramineghbalian Dec 15 2020 at 19:56
para ver os valores no FormData você deve usar o loop como abaixo:
for (let value of fd.values()) {
console.log(value);
}
você também pode ver o valor de certos dados usando a chave:
console.log(fd.get('key'));
Também tenha cuidado ao anexar vários arquivos por uma chave (em seu código = "upload") em loop, seus dados serão substituídos e apenas um deles será anexado no final, para enviar vários arquivos por uma entrada, você deve usar o []
após o nome de entrada como abaixo:
const getFileList = e.fileList.map((i) => {
return fd.append("upload[]", i.originFileObj);
});
O que significa um erro “Não é possível encontrar o símbolo” ou “Não é possível resolver o símbolo”?
George Harrison ficou chateado por suas letras de 'Hurdy Gurdy Man' de Donovan não terem sido usadas