-
Notifications
You must be signed in to change notification settings - Fork 16
FormData
Конструктор FormData() создает объект класса FormData
▼ FormData {}
▼ __proto__: FormData
► append: ƒ append()
► delete: ƒ delete()
► entries: ƒ entries()
► forEach: ƒ forEach()
► get: ƒ ()
► getAll: ƒ getAll()
► has: ƒ has()
► keys: ƒ keys()
► set: ƒ ()
► values: ƒ values()
► constructor: ƒ FormData()
► Symbol(Symbol.iterator): ƒ entries()
Symbol(Symbol.toStringTag): "FormData"
► __proto__: Objectvar formData = new FormData()
formData instanceof FormData // true📋 Объекты класса FormData предоставляют интефейс для манипулирования данными форм и могут быть отправлены на сервер с помощью XMLHttpRequest или Fetch API
| append | delete | get | set |
|---|
Принимает два аргумента - имя ключа и его значение
Если такого ключа еще нет, добавляет пару ключ/значение
Если такой ключ уже существует, добавляет ему новое значение
var formData = new FormData()
formData.append ( "username", "garevna" )
formData.append ( "token", "HgTY78-jdfhj91*/jskdfj" )formData.has ( "token" ) // trueformData.get ( "username" ) // "garevna"
formData.get ( "token" ) // "HgTY78-jdfhj91*/jskdfj"Возвращает массив всех значений, связанных с указанным в аргументе ключом
formData.append ( "pictures", "http://icecream.me/uploads/b0d4d73f21508dd67e0c57a590f582f0.png" )
formData.getAll ( "pictures" )
formData.append ( "pictures", "https://github.com/garevna/js-course/raw/master/images/js_cup-ico.png" )
formData.getAll ( "pictures" )Аргументы: ключ, значение
Если указанный аргументом ключ уже существует, устанавливает ему новое значение, в противном случае добавляет новый ключ и значение
formData.set ( "token", "gF&op*i91/54gkjHU" )
formData.get ( "token" ) // "gF&op*i91/54gkjHU"formData.delete ( "token" )
formData.get ("token") // nullВозвращает объект-итератор ( будем изучать позже )
Возвращает объект-итератор ( будем изучать позже )
☕ 1️⃣
var iterator = formData.keys()
iterator.next()
iterator.next()
...☕ 2️⃣
var iterator = formData.keys()
iterator.next()
iterator.next()
...☕ 3️⃣
var fileSelector = document.body.appendChild (
document.createElement ( 'input' )
)
fileSelector.type = "file"
let formData = new FormData()
fileSelector.onchange = function ( event ) {
formData.append ( "avatar", this.files[0] )
fetch ( 'https://httpbin.org/post', {
method: 'POST',
headers: {
'Content-Type': "multipart/form-data"
},
body: formData
})
.then (
response => response.json()
.then (
response => console.log ( response )
)
)
}var fileSelector = document.body.appendChild (
document.createElement ( 'input' )
)
fileSelector.type = "file"
let formData = new FormData()
fileSelector.onchange = function ( event ) {
formData.append ( "avatar", this.files[0] )
var request = new XMLHttpRequest()
request.open( "POST", "https://httpbin.org/post" )
request.onreadystatechange = function ( event ) {
if ( this.readyState < 4 ) return
console.log ( this.status, this.response )
}
request.send( formData )
}☕ 4️⃣
var fileSelector = document.body.appendChild (
document.createElement ( 'input' )
)
fileSelector.type = "file"
fileSelector.onchange = function ( event ) {
let file = this.files[0]
if ( file.type.indexOf ( 'image/' ) >= 0 ) {
var reader = new FileReader ()
reader.readAsArrayBuffer ( file )
reader.onload = function ( event ) {
fetch ( 'https://httpbin.org/post', {
method: 'POST',
headers: {
'Content-Type': file.type
},
body: new Blob ( [ this.result ], { type: file.type } )
})
.then ( response => console.log ( response ) )
}
}
}☕ 5️⃣
var fileSelector = document.body.appendChild (
document.createElement ( 'input' )
)
fileSelector.type = "file"
fileSelector.onchange = function ( event ) {
let file = this.files[0]
if ( file.type.indexOf ( 'image/' ) >= 0 ) {
var reader = new FileReader ()
reader.readAsArrayBuffer ( file )
reader.onload = function ( event ) {
fetch ( 'http://ptsv2.com/t/garevna/post', {
method: 'POST',
headers: {
'Content-Type': file.type
},
body: new Blob ( [ this.result ], { type: file.type } )
})
.then ( response => response.json()
.then ( response => console.log ( response ) )
)
}
}
}fetch ( 'http://ptsv2.com/t/garevna/d/890001/json')
.then ( response => {
let reader = response.body.getReader()
reader.read( response.body )
.then ( result => console.log ( result ) )
})
© Irina H.Fylyppova 2018
Использование данных материалов или любой их части коммерческими школами ( курсами ) является нарушением авторских прав
| 1 | 2 | 3 | 4 | 5 |
| 6 | 7 | 8 | 9 | 10 |
| 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 |
| ⏬ |
|---|
- Блок-схема алгоритма
- Developer Tools
- Chrome DevTools
- Переменные
- Оператор typeof
- Структуры данных
- Операторы присваивания
- Логические выражения
- Условные операторы
- Инкремент
- Свойство length
- Оператор цикла for
- UTF-8
Homework
- Приведение типов
- NaN | null | Infinity
- BigInt (ES10)
- Функции
- Методы
- Методы строк
- Методы массивов
- Date ()
Самостоятельная работа
Практика (XSS)
Homework
- Циклы while и do...while
- Циклы for...of и for...in
- Параметры по умолчанию
- Объект function
Практика
Homework
- Нативные и host-объекты
- Литерал объекта
- Унаследованные свойства
- Конструктор
- Модель наследования
- Публичные и приватные свойства
- Оператор in
1
Homework
- Итерирующие методы массивов
- Тестирование производительности
- SHA
Homework
- Размеры и прокрутка элемента
- Event Loop
- async | await
- API
- REST | HATEOAS
- status codes
JSON placeholder-
JSON server
fake chat
Homework
- strict mode
- Вычисляемые имена свойств
- Краткий синтаксис методов
- Краткий литерал объекта
- Классы
Homework
- :not(:defined)
- Shadow DOM
- Custom elements
- Lifecycle hooks
- whenDefined
- <template>
- slot
1
2
3
Homework
- npm
- webpack
Упражнение 1- ES6 модули
Упражнение 2- --mode | --watch
Упражнение 3
Упражнение 4
Упражнение 5
Упражнение 6
Упражнение 7
Упражнение 8
Homework
| ⏫ |
|---|

Дополнительно
Справочная инфо
Git Bush
TCP/IP
Коды символов