-
Notifications
You must be signed in to change notification settings - Fork 16
FileReader
garevna edited this page Oct 24, 2018
·
4 revisions
Создает экземпляр объекта, который позволяет веб-приложению асинхронно читать содержимое файлов ( объекты класса File ) на компьютере пользователя или объекты класса Blob
Не может читать объекты класса ReadableStream
var reader = new FileReader ()ƒ readAsArrayBuffer()
ƒ readAsBinaryString()
ƒ readAsDataURL()
ƒ readAsText()объект DOMError со свойствами name и message
✋ EMPTY : 0 ( данные еще не загружены )
✋ LOADING : 1 ( данные загружаются )
✋ DONE : 2 ( операция чтения завершена )
данные
✋ значение свойства result определено только после завершения операции чтения
✋ формат данных зависит от способа, с помощью которого процесс был вызван
✅ onabort
✅ onerror
✅ onload
✅ onloadend
✅ onloadstart
✅ onprogress☕ 1️⃣
✍ Разберите работу кода в Chrome DevTools:
var selector = document.body.appendChild ( document.createElement ( 'input' ) )
selector.type = 'file'
selector.onchange = function handleFiles( event ) {
fileReader.readAsDataURL ( event.target.files [0] )
fileReader.onload = function ( event ) {
picture.src = event.target.result
}
}
var picture = document.body.appendChild (
document.createElement ( 'img' )
)
var fileReader = new FileReader ()Сравните с уже знакомым методом URL.createObjectURL:
picture.src = URL.createObjectURL( selected )☕ 2️⃣
✍ Разберите работу кода в Chrome DevTools:
var selector = document.body.appendChild (
document.createElement ( 'input' )
)
selector.type = 'file'
selector.onchange = function handleFiles( event ) {
var selected = event.target.files [0]
header.innerText = selected.type
switch ( selected.type.split('/')[0] ) {
case 'image':
fileReader.readAsDataURL ( selected )
fileReader.onload = function ( event ) {
picture.src = event.target.result
}
break
case 'text' :
fileReader.readAsText ( selected )
fileReader.onload = function ( event ) {
demo.innerText = event.target.result
}
break
case 'application':
fileReader.readAsText ( selected )
fileReader.onload = function ( event ) {
demo.innerText = event.target.result
}
break
default:
fileReader.readAsArrayBuffer ( selected )
fileReader.onload = function ( event ) {
console.log ( event.target.result )
}
break
}
}
var picture = document.body.appendChild (
document.createElement ( 'img' )
)
var header = document.body.appendChild (
document.createElement ( 'h3' )
)
var demo = document.body.appendChild (
document.createElement ( 'pre' )
)
var fileReader = new FileReader ()☕ 3️⃣
✍ Разберите работу кода в Chrome DevTools:
var selector = document.body.appendChild (
document.createElement ( 'input' )
)
selector.type = 'file'
selector.multiple = true
selector.id = 'selectImages'
selector.style.display = 'none'
var label = document.body.appendChild (
document.createElement ( 'label' )
)
label.htmlFor = 'selectImages'
label.innerText = 'Select images'
selector.onchange = function ( event ) {
for ( var file of event.target.files ) {
if ( file.type.split('/')[0] !== 'image' ) return
var picture = document.createElement ( "img" )
document.body.appendChild( picture )
var fileReader = new FileReader ()
fileReader.onload = (
image => function ( e ) {
image.src = e.target.result
}
)( picture )
fileReader.readAsDataURL ( file )
}
}
© 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
Коды символов