Dieses Mal zeige ich Ihnen, wie H5 FileReader Lesedateien verteilt und welche Vorsichtsmaßnahmen für die FileReader-Verteilung zum Lesen von Dateien gelten. Das Folgende ist ein praktischer Fall sehen. .
Renderings
Die alte Regel besteht darin, zuerst die Renderings anzuzeigen
Stellen Sie zunächst einige Methoden und Ereignisse von FileReader in H5 vor
FileReader-Methode
名称 | 作用 |
---|---|
about() | 终止读取 |
readAsBinaryString(file) | 将文件读取为二进制编码 |
readAsDataURL(file) | 将文件读取为DataURL编码 |
readAsText(file, [encoding]) | 将文件读取为文本 |
readAsArrayBuffer(file) | 将文件读取为arraybuffer |
FileReader-Ereignis
名称 | 作用 |
---|---|
onloadstart | 读取开始时触发 |
onprogress | 读取中 |
onloadend | 读取完成触发,无论成功或失败 |
onload | 文件读取成功完成时触发 |
onabort | 中断时触发 |
onerror | 出错时触发 |
Code
Die Kernidee des verteilten Lesens von Dateien besteht darin, die Datei in Blöcke zu unterteilen Lesen Sie jeden M.
HTML-Teil
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <form> <fieldset> <legend>分步读取文件:</legend> <input type="file" id="File"> <input type="button" value="中断" id="Abort"> <p> <lable>读取进度:</lable> <progress id="Progress" value="0" max="100"></progress> </p> </fieldset> </form> <script src="./loadFile.js"></script> <script> var progress = document.getElementById('Progress');//进度条 var events = { load: function () { console.log('loaded'); }, progress: function (percent) { console.log(percent); progress.value = percent; }, success: function () { console.log('success'); } }; var loader; // 选择好要上传的文件后触发onchange事件 document.getElementById('File').onchange = function (e) { var file = this.files[0]; console.log(file) //loadFile.js loader = new FileLoader(file, events); }; document.getElementById('Abort').onclick = function () { loader.abort(); } </script> </body> </html>
loadFile.js-Teil
/* * 文件读取模块 * file 文件对象 * events 事件回掉对象 包含 success , load, progress */ var FileLoader = function (file, events) { this.reader = new FileReader(); this.file = file; this.loaded = 0; this.total = file.size; //每次读取1M this.step = 1024 * 1024; this.events = events || {}; //读取第一块 this.readBlob(0); this.bindEvent(); } FileLoader.prototype = { bindEvent: function (events) { var _this = this, reader = this.reader; reader.onload = function (e) { _this.onLoad(); }; reader.onprogress = function (e) { _this.onProgress(e.loaded); }; // start 、abort、error 回调暂时不加 }, // progress 事件回掉 onProgress: function (loaded) { var percent, handler = this.events.progress;//进度条 this.loaded += loaded; percent = (this.loaded / this.total) * 100; handler && handler(percent); }, // 读取结束(每一次执行read结束时调用,并非整体) onLoad: function () { var handler = this.events.load; // 应该在这里发送读取的数据 handler && handler(this.reader.result); // 如果未读取完毕继续读取 if (this.loaded < this.total) { this.readBlob(this.loaded); } else { // 读取完毕 this.loaded = this.total; // 如果有success回掉则执行 this.events.success && this.events.success(); } }, // 读取文件内容 readBlob: function (start) { var blob, file = this.file; // 如果支持 slice 方法,那么分步读取,不支持的话一次读取 if (file.slice) { blob = file.slice(start, start + this.step); } else { blob = file; } this.reader.readAsText(blob); }, // 中止读取 abort: function () { var reader = this.reader; if(reader) { reader.abort(); } } }
Ich glaube, Sie haben die Methode gemeistert, nachdem Sie den Fall in diesem Artikel gelesen haben Für weitere spannende Informationen beachten Sie bitte andere verwandte Themen im chinesischen PHP-Website-Artikel!
Empfohlene Lektüre:
Eine Zusammenfassung verschiedener falscher Verwendungen von H5
So erstellen Sie ein dynamisches 3D-Diagramm mit Canvas
Das obige ist der detaillierte Inhalt vonWie liest der FileReader von H5 Dateien verteilt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!