#Angular File Upload
Angular File Upload is a module for the AngularJS framework. Supports drag-n-drop upload, upload progress, validation filters and a file upload queue. It supports native HTML5 uploads, but degrades to a legacy iframe upload method for older browsers. Works with any server side platform which supports standard HTML form uploads.
When files are selected or dropped into the component, one or more filters are applied. Files which pass all filters are added to the queue and are ready to be uploaded.
- The AngularJS framework
- ES5 (Array.indexOf, Array.forEach, Array.filter, Array.every, Function.bind, Date.now) A shim is provided for older browsers
- ngFileSelect: Should be applied to
<input type="file" />
. The selected files are added to the uploaded queue if they have passed the filters. - ngFileDrop: Set up a drop area. Usually applied to the entire document. Caught files are added to the uploaded queue if they have passed the filters.
- ngFileOver: Should be applied to the element which will change class when files are about to be placed on the drop area. By default it adds the class
ng-file-over
but a different class can be specified with the parameter attributeng-file-over="className"
.
- $fileUploader: Manages the upload queue and the uploading of files
- scope
{Object}
: Scope for HTML update, default is$rootScope
- url
{String}
: Path on the server to upload files - alias
{String}
: Name of the field which will contain the file, default isfile
- queue
{Array}
: Items to be uploaded - progress
{Number}
: Upload queue progress percentage - headers
{Object}
: Headers to be sent along with the files - formData
{Array}
: Data to be sent along with the files - filters
{Array}
: Filters to be applied to the files before adding them to the queue. If the filter returnstrue
the file will be added to the queue - autoUpload
{Boolean}
: Automatically upload files after adding them to the queue - method
{String}
: It's a request method. By defaultPOST
- removeAfterUpload
{Boolean}
: Remove files from the queue after uploading - hasHTML5
{Boolean}
: Checks whether browser has HTML5 upload support - isUploading
{Boolean}
:true
if an upload is in progress
- bind
function( event, handler ) {
: Registers an event handler - trigger
function( event[, params ]) {
: Executes all handlers bound to this event - addToQueue
function( items, options ) {
: Add items to the queue, whereitems
is aFileList
,File
orInput
, andoptions
is anObject
- removeFromQueue
function( value ) {
: Remove an item from the queue, wherevalue
is a queue elementItem
or index - clearQueue
function() {
: Removes all elements from the queue - getIndexOfItem
function( Item ) { return [Number]; }
: Returns the index of theItem
queue element - getReadyItems
function() { return [Array]; }
: Return items are ready to upload - getNotUploadedItems
function() { return [Array]; }
: Return an array of all pending items on the queue - uploadItem
function( value ) {
: Uploads an item, wherevalue
is a queue elementItem
or index - uploadAll
function() {
: Upload all pending items on the queue
- url
{String}
: Path on the server in which this file will be uploaded - alias
{String}
: Name of the field which will contain the file, default isfile
- headers
{Object}
: Headers to be sent along with this file - formData
{Array}
: Data to be sent along with this file - progress
{Number}
: File upload progress percentage - index
{Number}
- A sequence number upload - method
{String}
: It's a request method. By defaultPOST
- removeAfterUpload
{Boolean}
: Remove this file from the queue after uploading - isReady
{Boolean}
- File is ready to upload - isUploading
{Boolean}
:true
if the file is being uploaded - isUploaded
{Boolean}
:true
if the file was uploaded successfully - isComplete
{Boolean}
-true
if the file was uploaded - uploader
{Object}
: Reference to the parentUploader
object for this file
- remove
function() {
: Remove this file from the queue - upload
function() {
: Upload this file
var uploader = $fileUploader.create({
filters: [
function( item ) { // A user-defined filter
console.log( 'filter1' );
return true;
}
]
});
// Another user-defined filter
uploader.filters.push(function( item ) {
console.log( 'filter2' );
return true;
});
The queue already has registered a default filter that looks like this:
function( item ) {
return angular.isElement( item ) ? true : !!item.size;
}
- afteraddingfile
function( event, item ) {
: Fires after adding a single file to the queue - afteraddingall
function( event, items ) {
: Fires after adding all the dragged or selected files to the queue - beforeupload
function( event, items ) {
: Fires before uploading an item - changedqueue
function( event, [item|items] ) {
: When the queue has changed as a result of adding or removing elements - progress
function( event, item, progress ) {
: On file upload progress - success
function( event, xhr, item, response ) {
: On file successfully uploaded - error
function( event, xhr, item[, response ]) {
: On upload error - complete
function( event, xhr, item, response ) {
: On file upload complete (independently of the sucess of the operation) - progressall
function( event, progress ) {
: On upload queue progress - completeall
function( event, items ) {
: On all loaded when uploading an entire queue, or on file loaded when uploading a single independent file
var uploader = $fileUploader.create();
uploader.bind( 'progress', function( event, item, progress ) {
console.log( 'Progress: ' + progress );
});
- How to add the previously uploaded files in the queue?
// Add a item to the queue
uploader.queue.push({
example: {}, // your data here
isUploaded: true
});
Angular File Upload - модуль загрузки файлов (html5 + iframe) для фреймворка AngularJS. Поддерживает drag-n-drop загрузку, индикацию прогресса загрузки, очередь. В старых браузерах деградирует до iframe загрузчика.
В общих чертах работа модуля выглядит так: директивы "ловят" файлы и добавляют их в очередь, если те прошли фильтры, после чего "загрузчик файлов" может ими (элементами очереди) манипулировать.
- AngularJS фреймворк
- ES5 (Array.indexOf, Array.forEach, Array.filter, Array.every, Function.bind, Date.now)
- ngFileSelect - применяется к
<input type="file" />
. Выбранные файлы добавляются в очередь загрузки, если они прошли фильтры. - ngFileDrop - задает область сброса файлов / элемент, который будет ловить файлы. Как правило, применяется ко всему документу. Пойманные файлы добавляются в очередь загрузки, если они прошли фильтры.
- ngFileOver - применяется к элементу, который будет реагировать (менять класс), когда файлы находятся над областью сброса. По умолчанию добавляется класс
ng-file-over
. Другой класс можно задать в параметре атрибутаng-file-over="className"
.
- $fileUploader - управляет очередью и загрузкой файлов
- scope
{Object}
- ссылка на scope для обновления html. Если параметр опущен, используется$rootScope
- url
{String}
- путь на сервере, по которому будут загружаться файлы - alias
{String}
- псевдоним файла - queue
{Array}
- очередь загрузки - progress
{Number}
- прогресс загрузки очереди - headers
{Object}
- заголовки, которые будут переданы вместе с файлами - formData
{Array}
- данные, отправляемые вместе с файлами - filters
{Array}
- фильтры, применяемые к [файлу|элементу] перед добавлением его в очередь. Если фильтр возвращаетtrue
, [файл|элемент] будет добавлен в очередь - autoUpload
{Boolean}
- загружать автоматически после добавления элемента в очередь - method
{String}
: - метод запроса. По умолчаниюPOST
- removeAfterUpload
{Boolean}
- удалить файлы после загрузки - hasHTML5
{Boolean}
- проверяет, поддерживает ли браузер html5 загрузку - isUploading
{Boolean}
- загрузчик в процессе загрузки
- bind
function( event, handler ) {
- регистрирует обработчик события - trigger
function( event[, params ]) {
- выполняет все обработчики, связанные с данным событием - addToQueue
function( items, options ) {
- где items [FileList|File|Input], options [Object] - removeFromQueue
function( value ) {
- где value элемент очереди или его индекс [Item|Index] - clearQueue
function() {
- удаляет все элементы из очереди - getIndexOfItem
function( item ) { return [Number]; }
- где item элемент очереди - getReadyItems
function() { return [Array]; }
- Возвращает элементы готовые к загрузке - getNotUploadedItems
function() { return [Array]; }
- возвращает массив не загруженных элементов - uploadItem
function( value ) {
- где value элемент очереди или его индекс [Item|Index] - uploadAll
function() {
- загружает все незагруженные элементы
- url
{String}
- путь на сервере, по которому будет загружен файл - alias
{String}
- псевдоним файла - headers
{Object}
- заголовки, которые будут переданы вместе с файлом - formData
{Array}
- данные, отправляемые вместе с файлом - progress
{Number}
- прогресс загрузки файла - index
{Number}
- индекс / порядковый номер загрузки - method
{String}
: - метод запроса. По умолчаниюPOST
- removeAfterUpload
{Boolean}
- удалить файл после загрузки - isReady
{Boolean}
- файл готов к загрузке - isUploading
{Boolean}
- файл в процессе загрузки - isUploaded
{Boolean}
- файл успешно загружен - isComplete
{Boolean}
- файл загружен - uploader
{Object}
- ссылка на загрузчик
- remove
function() {
- удаляет элемент - upload
function() {
- загружает элемент
var uploader = $fileUploader.create({
filters: [
function( item ) { // first user filter
console.log( 'filter1' );
return true;
}
]
});
// second user filter
uploader.filters.push(function( item ) {
console.log( 'filter2' );
return true;
});
По умолчанию в массиве фильтров уже присутствует один фильтр, который имеет вид:
function( item ) {
return angular.isElement( item ) ? true : !!item.size;
}
- afteraddingfile
function( event, item ) {
- после добавления файла в очередь - afteraddingall
function( event, items ) {
- после добавления всех файлов в очередь - beforeupload
function( event, items ) {
- перед загрузкой файла - changedqueue
function( event, [item|items] ) {
- очередь изменена - progress
function( event, item, progress ) {
- прогресс загрузки файла - success
function( event, xhr, item, response ) {
- файл успешно загружен - error
function( event, xhr, item[, response ]) {
- ошибка при загрузке - complete
function( event, xhr, item, response ) {
- файл загружен - progressall
function( event, progress ) {
- прогресс загрузки очереди - completeall
function( event, items ) {
- "очередь загружена", если была инициирована загрузка всей очереди; иначе "файл загружен", если была инициирована загрузка файла
var uploader = $fileUploader.create();
uploader.bind( 'progress', function( event, item, progress ) {
console.log( 'Progress: ' + progress );
});
- Как добавить ранее загруженные файлы в очередь?
// Add a item to the queue
uploader.queue.push({
example: {}, // your data here
isUploaded: true
});