FormData.append ("ключ", "значение") не работает - PullRequest
98 голосов
/ 13 октября 2011

Можете ли вы сказать мне, что не так с этим:

var formdata = new FormData();
formdata.append("key", "value");
console.log(formdata);

Мой вывод выглядит так, я не могу найти свою пару "ключ" - "значение"

FormData
*__proto__: FormData
**append: function append() { [native code] }
***arguments: null
***caller: null
***length: 0
***name: "append"
***prototype: append
***__proto__: function Empty() {}
*constructor: function FormData() { [native code] }
**arguments: null
**caller: null
**length: 0
**name: "FormData"
**prototype: FormData
**toString: function toString() { [native code] }
*__proto__: Object
**__proto__: Object
**__defineGetter__: function __defineGetter__() { [native code] }
**__defineSetter__: function __defineSetter__() { [native code] }
**__lookupGetter__: function __lookupGetter__() { [native code] }
**__lookupSetter__: function __lookupSetter__() { [native code] }
**constructor: function Object() { [native code] }
**hasOwnProperty: function hasOwnProperty() { [native code] }
**isPrototypeOf: function isPrototypeOf() { [native code] }
**propertyIsEnumerable: function propertyIsEnumerable() { [native code] }
**toLocaleString: function toLocaleString() { [native code] }
**toString: function toString() { [native code] }
**valueOf: function valueOf() { [native code] }

Я могу'Т понять!Вчера это работало так хорошо, а сегодня моя голова ломала клавиатуру столько раз!Firefox, Chrome, оба одинаковые: /

Ответы [ 8 ]

113 голосов
/ 30 декабря 2012

Новое в Chrome 50+ и Firefox 39+ (соответственно, 44+):

  • formdata.entries() (в сочетании с Array.from() для отладки)
  • formdata.get(key)
  • и другие очень полезные методы

Оригинальный ответ:

Что я обычно делаю для отладки a FormData объект, просто отправьте его (куда угодно!) И проверьте журналы браузера (например, вкладку Chrome devtools 'Network).

Вам не нужна такая же Ajax-инфраструктура.Вам не нужны никакие детали.Просто отправьте:

var xhr = new XMLHttpRequest;
xhr.open('POST', '/', true);
xhr.send(data);

Легко.

51 голосов
/ 13 октября 2011

Вы говорите, что это не работает.Чего вы ожидаете?

Нет способа получить данные из объекта FormData;он просто предназначен для отправки данных вместе с объектом XMLHttpRequest (для метода send).

Обновление почти пять лет спустя: в некоторых новых браузерах это больше неЗначение true, и теперь вы можете видеть данные, предоставленные FormData, в дополнение к простой вставке данных в него. См. Принятый ответ для получения дополнительной информации.

17 голосов
/ 04 августа 2013

Возможно, у вас возникла та же проблема, что и у меня изначально. Я пытался использовать FormData, чтобы получить все свои входные файлы для загрузки изображения, но в то же время я хотел добавить идентификатор сеанса к информации, передаваемой на сервер. Все это время, подумал я, добавляя информацию, вы сможете увидеть ее на сервере, получив доступ к объекту. Я был неправ. При добавлении в FormData способ проверки добавленной информации на сервере заключается в простом запросе $_POST['*your appended data*']. вот так:

ЯШ:

$('form').submit(function(){
    var sessionID = 8;
    var formData = new FormData(this);
    formData.append('id', sessionID);

    $.ajax({
        url: "yoururl.php",
        data: formData,
        processData: false,
        contentType: false,
        type: 'POST',
        success: function(data){
            alert(data);
        }
    });
});

затем на php:

$sessionID = $_POST['id'];
$files = $_FILES['image'];

$foreach ($files as $key=>val){
    //...
}
16 голосов
/ 14 июля 2014

Если вы находитесь в Chrome, вы можете проверить почтовые данные

Вот как проверить почтовые данные

  1. Перейти на вкладку "Сеть"
  2. Найдите ссылку, по которой вы отправляете данные сообщения
  3. Нажмите на нее
  4. В Заголовках вы можете проверить Запрос полезной нагрузки, чтобы проверить почтовые данные

Chrome's DevTools

8 голосов
/ 29 октября 2015

это видно вам нужно использовать console.log(formData.getAll('your key')); Смотри https://developer.mozilla.org/en-US/docs/Web/API/FormData/getAll

2 голосов
/ 17 октября 2018

React Version

Убедитесь, что заголовок имеет 'content-type': 'multipart/form-data'

_handleSubmit(e) {
    e.preventDefault();
    const formData = new FormData();
          formData.append('file', this.state.file);
    const config = {
      headers: {
        'content-type': 'multipart/form-data'
      }
    }

     axios.post("/upload", formData, config)
         .then((resp) => {
             console.log(resp)
         }).catch((error) => {
    })
  }

  _handleImageChange(e) {
    e.preventDefault();
    let file = e.target.files[0];
    this.setState({
      file: file
    });
  }

View

  #html
 <input className="form-control"
    type="file" 
    onChange={(e)=>this._handleImageChange(e)} 
 />
2 голосов
/ 02 августа 2018

В моем случае в браузере Edge:

  const formData = new FormData(this.form);
  for (const [key, value] of formData.entries()) {
      formObject[key] = value;
  }

дай мне ту же ошибку

Так что я не использую FormData и просто строю объект вручную

import React from 'react';    
import formDataToObject from 'form-data-to-object';

  ...

let formObject = {};

// EDGE compatibility -  replace FormData by
for (let i = 0; i < this.form.length; i++) {
  if (this.form[i].name) {
    formObject[this.form[i].name] = this.form[i].value;
  }
}

const data = formDataToObject.toObj(formObject): // convert "user[email]":"customer@mail.com" => "user":{"email":"customer@mail.com"}

const orderRes = await fetch(`/api/orders`, {
        method: 'POST',
        credentials: 'same-origin',
        headers: {
          'Content-Type': 'application/json'
        },
        body: JSON.stringify(data)
      });

const order = await orderRes.json();
1 голос
/ 04 ноября 2018

данные формы не отображаются в консоли веб-браузера

for (var data of formData) {
  console.log(data);
}

попробуйте так, как он покажет

...