Esattamente quello che ti serve :) È possibile scegliere la versione di richiamata o versione Promessa. Nota che le promesse funzioneranno solo in IE con Promise polyfill lib.Potrai inserire questo codice una volta su una pagina e questa funzione apparirà in tutti i tuoi file.
L'evento loadend viene attivato quando il progresso si è fermato sul caricamento di una risorsa (ad esempio dopo "errore", "abortire", o "carico" sono stati spedito) versione
Callback
File.prototype.convertToBase64 = function(callback){
var reader = new FileReader();
reader.onloadend = function (e) {
callback(e.target.result, e.target.error);
};
reader.readAsDataURL(this);
};
$("#asd").on('change',function(){
var selectedFile = this.files[0];
selectedFile.convertToBase64(function(base64){
alert(base64);
})
});
versione Promessa
File.prototype.convertToBase64 = function(){
return new Promise(function(resolve, reject) {
var reader = new FileReader();
reader.onloadend = function (e) {
resolve({
fileName: this.name,
result: e.target.result,
error: e.target.error
});
};
reader.readAsDataURL(this);
}.bind(this));
};
FileList.prototype.convertAllToBase64 = function(regexp){
// empty regexp if not set
regexp = regexp || /.*/;
//making array from FileList
var filesArray = Array.prototype.slice.call(this);
var base64PromisesArray = filesArray.
filter(function(file){
return (regexp).test(file.name)
}).map(function(file){
return file.convertToBase64();
});
return Promise.all(base64PromisesArray);
};
$("#asd").on('change',function(){
//for one file
var selectedFile = this.files[0];
selectedFile.convertToBase64().
then(function(obj){
alert(obj.result);
});
});
//for all files that have file extention png, jpeg, jpg, gif
this.files.convertAllToBase64(/\.(png|jpeg|jpg|gif)$/i).then(function(objArray){
objArray.forEach(function(obj, i){
console.log("result[" + obj.fileName + "][" + i + "] = " + obj.result);
});
});
})
.210
html
<input type="file" id="asd" multiple/>
fonte
2015-10-21 13:35:33
E cosa non hai capito dell'API di file HTML5? Cosa hai provato? Cosa non ha funzionato? – epascarello
@epascarello non sono completamente supportati in realtà http://caniuse.com/#feat=fileapi ho bisogno di un aggiramento, soprattutto perché le versioni di Android sono ancora usate (vecchie versioni) così come per le vecchie versioni di iOS, e anch'io vorrei piace coinvolgere IE9 che è ancora molto usato: P – bombastic
una soluzione per cosa? Cosa stai cercando di fare con il file? 'base64file()' - è un plugin? – David