suchen
HeimWeb-Frontendjs-TutorialAjax-Fortschrittsbalken-Download-Implementierungsbeispielcode basierend auf Blod

In diesem Artikel wird hauptsächlich der Beispielcode für die Implementierung des Ajax-Fortschrittsbalken-Downloads basierend auf Blod vorgestellt. Der Herausgeber findet ihn recht gut, daher werde ich ihn jetzt mit Ihnen teilen und als Referenz verwenden. Folgen wir dem Editor, um einen Blick darauf zu werfen

Normaler Browser-Download

Wenn Sie in der Webentwicklung die Download-Funktion implementieren möchten, verwenden Sie häufig eine neu geöffnete Webseite Oder verwenden Sie iframe. Die Implementierung ist eigentlich sehr einfach:

<a target="_blank" href="download.zip" rel="external nofollow" >点击下载</a>
//或者
<iframe style="display:none" src="download.zip"></iframe>

Nachdem der Benutzer auf das a-Tag geklickt hat, um einen neuen Tab zu öffnen, oder nach dem Öffnen des Iframes, akzeptiert der Browser eine Download-Antwort und lädt den Anhang herunter. Tatsächlich bedeutet der sogenannte Anhang-Download, dass der Browser, nachdem er den Header der Antwortnachricht gelesen hat, ein Download-Eingabeaufforderungsfeld generiert und den Download der Datei fortsetzt, nachdem der Benutzer dies bestätigt hat. Eine Datei ist eigentlich ein Stream. Der Browser verwaltet diesen Übertragungsprozess automatisch und generiert automatisch einen Fortschrittsbalken, eine Schaltfläche zum Stoppen des Downloads, eine Schaltfläche zum Abbrechen des Downloads und eine Schaltfläche zum Anzeigen der heruntergeladenen Bytenummer. usw. . Der Browser erledigt dies automatisch für uns und der gesamte Vorgang unterliegt nicht unserer Kontrolle.

Ajax-Download

Browser-Unterstützung für den Download kann grundsätzlich unsere Anforderungen erfüllen Methode macht wenig Sinn. Es gibt jedoch immer noch einige Szenarien, die Browser-Downloads nicht erfüllen können. Beispielsweise muss unsere Webanwendung den Download-Fortschritt überwachen oder nach Abschluss des Downloads ein bestimmtes Ereignis auslösen, oder die Webanwendung kann den Download-Vorgang automatisch abbrechen Verwenden Sie einen Worker, um einen Hintergrund zu erstellen, auf dem Download und mehr ausgeführt werden. Für die oben genannten Situationen können wir einen Ajax-Download basierend auf dem Blod-Objekt verwenden.

Das Herunterladen von Anhängen mit Ajax ist dasselbe wie das Hochladen von Anhängen mit Ajax, und der Browser muss Ajax2.0 unterstützen. Tatsächlich unterscheidet sich der sogenannte Download nicht von einer gewöhnlichen Ajax-Anfrage. Bei Downloads handelt es sich jedoch im Allgemeinen um Binärdateien, bei denen kein JavaScript-Typ erforderlich ist die Binärdatei. Das ist Blut. Legen Sie daher den Antworttyp und den Wert von „responseType“ auf „blod“ fest:

var xhr =new XMLHttpRequest();
xhr.open(option.type ? option.type.toUpperCase() : &#39;GET&#39;, url, true);
xhr.responseType = &#39;blob&#39;;

erfordert, dass der Feldwert „responseType“ des XMLHttpRequest-Objekts „blob“ ist. Was ist also das Blutobjekt?

Blob-Objekt

MDN beschreibt es als:

Blob-Objekt ist ein dateiähnliches Objekt, das schreibgeschützte Rohdaten enthält. Die Daten in einem Blob-Objekt müssen nicht unbedingt in ihrer nativen Form in JavaScript vorliegen. Die Dateischnittstelle basiert auf Blob, erbt die Funktionen von Blob und erweitert die Unterstützung für lokale Dateien auf dem Computer des Benutzers. Durch das Blob-Objekt können wir einen Binärstrom in ein Objekt kapseln.

Wenn Sie die dateibezogene API von HTML5 kennen, sollten Sie mit dem Blod-Objekt vertraut sein. Blod kann einen Bytestream in eine Datei kapseln. Wenn der ResponseType-Wert des XMLHttpRequest-Objekts Blob ist, können wir den Antworttext als Blob-Objekt behandeln.

xhr.onload = function () {
  //对于重定向的文件不予理会
  if (this.status >= 200 && this.status < 300) {
    var blob = new Blob([this.response], {type: this.response.type});
  }
}

Verwenden Sie Ajax, um die Datei herunterzuladen, speichern Sie die Datei dann als Blob-Objekt und speichern Sie sie im Browser zwischen. Wie können Benutzer also Dateien auf ihrer Festplatte speichern?

Speichern Sie das Blob-Objekt auf der Festplatte

Wir können den Browser-Download nachahmen, ein Tag oder einen Iframe generieren und dann eine URL generieren, damit wir zurückkehren zum Browser Nach dem Herunterladen generiert der Browser automatisch ein Fenster zum Speichern des Anhangs. Die URL kann mit der Methode URL.createObjectURL(blob) abgerufen werden. URL.createObjectURL unterstützt Blob-Objekte und Dateiobjekte und kann eine virtuelle URL generieren, sodass der aktuelle Benutzer auf diese Objekte zugreifen kann, natürlich auch auf Downloads. Anders als beim direkten Herunterladen vom Server erfolgt der Download hier intern für den Client und verwendet kein Netzwerk-IO, sodass der Download nahezu augenblicklich erfolgt. Nach dem Generieren der URL muss diese jedoch freigegeben werden, da die Blob-Ressource sonst nicht durch Garbage Collection erfasst wird. Sie können URL.revokeObjectURL verwenden, um die URL freizugeben und die Blob-Ressource freizugeben. Für den IE-Browser gibt es einen eigenen Satz von Blob-Objektverarbeitungsstrategien, bei denen es sich um zwei Navigatormethoden handelt: msSaveOrOpenBlob und msSaveBlob.

//ie的下载
if (window.navigator.msSaveOrOpenBlob) {
  navigator.msSaveBlob(blob, fileName);
} else {
  //非ie的下载
  var link = document.createElement(&#39;a&#39;);
  link.href = window.URL.createObjectURL(blob);
  link.download = fileName;
  link.click();
  window.URL.revokeObjectURL(link.href);
}

Fortschrittsbalken und Download-Abbruch

Dann gibt es noch den Fortschrittsbalken und die Download-Abbruchfunktion. Tatsächlich verfügt das XMLHttpRequest-Objekt über ein Fortschrittsereignis, das wir jedoch normalerweise durchführen Ajax-Anfragen Ignorieren Sie ihn schließlich, und es besteht keine Notwendigkeit, einen Fortschrittsbalken für sie festzulegen. Da das Herunterladen von Anhängen jedoch etwas Zeit in Anspruch nimmt, ist es notwendig, einen Fortschrittsbalken dafür zu entwickeln. Durch Abhören des Fortschrittsereignisses können wir den Download-Fortschritt ermitteln.

Verwenden Sie die Abbruchfunktion des XMLHttpRequest-Objekts, um den Download abzubrechen. Darüber hinaus kann das Ladeereignis den Download-Abschluss und das Fehlerereignis den Download-Fehler überwachen. Kurz gesagt, die Ereignisse und Methoden eines Ajax-Downloads und einer gewöhnlichen Ajax-Anfrage sind genau die gleichen.

Leistungsoptimierung und Same-Origin-Richtlinie

Ajax-Downloads beanspruchen wie lange Verbindungen mehr Bandbreite als normale Anfragen, insbesondere Downloads, die mehr Bandbreite beanspruchen. Daher können andere Ajax-Anfragen während des Downloadvorgangs blockiert werden. Daher wird empfohlen, dass die von Ajax heruntergeladenen Ressourcen und andere angeforderte Ressourcen unterschiedliche Domänennamen verwenden. Dies führt jedoch zu einem neuen Problem – dem gleichen Ursprungsrichtlinienproblem.

Die Same-Origin-Richtlinie ist der Grundstein der Browsersicherheit. Ohne eine Same-Origin-Richtlinie kann jede Website einen CSRF-Angriff starten. Wenn nicht garantiert werden kann, dass die URL der heruntergeladenen Ressource denselben Ursprung hat wie die URL der aktuellen Seite, wird die gleiche Ursprungsrichtlinie ausgelöst und der Download schlägt fehl. Daher ist eine domänenübergreifende Ajax-Verarbeitung erforderlich. Im Vergleich zu den Download-Methoden von Iframe und New Tab (tatsächlich verfügt Iframe auch über eine Same-Origin-Richtlinie, die erfordert, dass die Seite innerhalb des Iframes und die übergeordnete Seite nicht auf den Inhalt des anderen zugreifen können, die Download-Funktion umfasst diese Art jedoch nicht des Zugriffs auf die Inhalte des anderen, daher ist der Iframe-Download nicht von der Same-Origin-Richtlinie betroffen), der Ajax-Download ist immer noch Ajax-Natur und wird daher von der Same-Origin-Richtlinie des Browsers beeinflusst. Wenn Sie daher einen Anhang von einer nicht originalen Quelle herunterladen, muss der Server, auf dem sich der Anhang befindet, CORS unterstützen. Wenn der Server auf Cookies zugreifen muss, muss „withCredentials“ des XMLHttpRequest-Objekts auf „true“ gesetzt werden.

Gleichzeitig können wir aufgrund der gleichen Ursprungsrichtlinie Ajax nicht zum Herunterladen von Ressourcen von Drittanbietern verwenden, da die üblichen Download-Dienste keine Cors-Verarbeitung durchführen, z. B. Iframe-Downloads oder neue Tab-Downloads Die Methode ist von der Same-Origin-Richtlinie nicht betroffen, sodass keine Cors-Verarbeitung erforderlich ist. Dies schränkt die Anwendbarkeit des Ajax-Downloads erheblich ein.

Zusammenfassung:

Lassen Sie uns abschließend die Nutzungsszenarien des Ajax-Downloads zusammenfassen:

1. Szenarien, in denen der Download-Fortschritt überwacht werden muss, z Es wurde festgestellt, dass der Download-Fortschritt des Benutzers zu langsam war und andere Lösungen proaktiv bereitgestellt wurden.

2. Nach Abschluss des Downloads muss ein bestimmtes Ereignis ausgelöst werden, z. B. ein Desktop-Benachrichtigungs-Popup.

3. Ein Hintergrund-Download ist erforderlich. Beispielsweise können wir den Anhang heimlich herunterladen, nachdem der Benutzer die Webseite geöffnet hat, ihn zwischenspeichern und ihn dann lokal speichern, wenn der Benutzer den Anhang wirklich herunterladen möchte. Wir können sogar Worker verwenden, um einen Hintergrundthread zu erstellen, um sicherzustellen, dass der Downloadvorgang die normale Darstellung der Seite nicht beeinträchtigt.

4. Es muss heruntergeladen und nicht auf der Festplatte gespeichert werden, aber die Webanwendung verarbeitet den Anhang direkt. Beispielsweise verwendet pdf.js zum Herunterladen Ajax.

Abschließend präsentiere ich eine Ajax-Download-Demo des Autors: ajaxDownloadDemo_jb51.rar

Das Obige habe ich hoffentlich für Sie zusammengestellt hilfreich für Sie in der Zukunft.

Verwandte Artikel:

So konvertieren Sie einfache Entitätsklassen und XML-Dateien ineinander und voneinander

Verwenden Sie Ajax, um Razor teilweise zu aktualisieren Seiten (grafisches Tutorial)

AjaxFileUpload+Struts2 implementiert die Funktion zum Hochladen mehrerer Dateien

Das obige ist der detaillierte Inhalt vonAjax-Fortschrittsbalken-Download-Implementierungsbeispielcode basierend auf Blod. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Python vs. JavaScript: Entwicklungsumgebungen und ToolsPython vs. JavaScript: Entwicklungsumgebungen und ToolsApr 26, 2025 am 12:09 AM

Sowohl Python als auch JavaScripts Entscheidungen in Entwicklungsumgebungen sind wichtig. 1) Die Entwicklungsumgebung von Python umfasst Pycharm, Jupyternotebook und Anaconda, die für Datenwissenschaft und schnelles Prototyping geeignet sind. 2) Die Entwicklungsumgebung von JavaScript umfasst Node.JS, VSCODE und WebPack, die für die Entwicklung von Front-End- und Back-End-Entwicklung geeignet sind. Durch die Auswahl der richtigen Tools nach den Projektbedürfnissen kann die Entwicklung der Entwicklung und die Erfolgsquote der Projekte verbessert werden.

Ist JavaScript in C geschrieben? Prüfung der BeweiseIst JavaScript in C geschrieben? Prüfung der BeweiseApr 25, 2025 am 12:15 AM

Ja, der Motorkern von JavaScript ist in C. 1) Die C -Sprache bietet eine effiziente Leistung und die zugrunde liegende Steuerung, die für die Entwicklung der JavaScript -Engine geeignet ist. 2) Die V8-Engine als Beispiel wird sein Kern in C geschrieben, wobei die Effizienz und objektorientierte Eigenschaften von C kombiniert werden.

JavaScripts Rolle: das Web interaktiv und dynamisch machenJavaScripts Rolle: das Web interaktiv und dynamisch machenApr 24, 2025 am 12:12 AM

JavaScript ist das Herzstück moderner Websites, da es die Interaktivität und Dynamik von Webseiten verbessert. 1) Es ermöglicht die Änderung von Inhalten, ohne die Seite zu aktualisieren, 2) Webseiten durch DOMAPI zu manipulieren, 3) Komplexe interaktive Effekte wie Animation und Drag & Drop, 4) die Leistung und Best Practices optimieren, um die Benutzererfahrung zu verbessern.

C und JavaScript: Die Verbindung erklärteC und JavaScript: Die Verbindung erklärteApr 23, 2025 am 12:07 AM

C und JavaScript erreichen die Interoperabilität durch WebAssembly. 1) C -Code wird in das WebAssembly -Modul zusammengestellt und in die JavaScript -Umgebung eingeführt, um die Rechenleistung zu verbessern. 2) In der Spieleentwicklung kümmert sich C über Physik -Engines und Grafikwiedergabe, und JavaScript ist für die Spiellogik und die Benutzeroberfläche verantwortlich.

Von Websites zu Apps: Die verschiedenen Anwendungen von JavaScriptVon Websites zu Apps: Die verschiedenen Anwendungen von JavaScriptApr 22, 2025 am 12:02 AM

JavaScript wird in Websites, mobilen Anwendungen, Desktop-Anwendungen und serverseitigen Programmierungen häufig verwendet. 1) In der Website -Entwicklung betreibt JavaScript DOM zusammen mit HTML und CSS, um dynamische Effekte zu erzielen und Frameworks wie JQuery und React zu unterstützen. 2) Durch reaktnatives und ionisches JavaScript wird ein plattformübergreifendes mobile Anwendungen entwickelt. 3) Mit dem Elektronenframework können JavaScript Desktop -Anwendungen erstellen. 4) Node.js ermöglicht es JavaScript, auf der Serverseite auszuführen und unterstützt hohe gleichzeitige Anforderungen.

Python gegen JavaScript: Anwendungsfälle und Anwendungen verglichenPython gegen JavaScript: Anwendungsfälle und Anwendungen verglichenApr 21, 2025 am 12:01 AM

Python eignet sich besser für Datenwissenschaft und Automatisierung, während JavaScript besser für die Entwicklung von Front-End- und Vollstapel geeignet ist. 1. Python funktioniert in Datenwissenschaft und maschinellem Lernen gut und unter Verwendung von Bibliotheken wie Numpy und Pandas für die Datenverarbeitung und -modellierung. 2. Python ist prägnant und effizient in der Automatisierung und Skripten. 3. JavaScript ist in der Front-End-Entwicklung unverzichtbar und wird verwendet, um dynamische Webseiten und einseitige Anwendungen zu erstellen. 4. JavaScript spielt eine Rolle bei der Back-End-Entwicklung durch Node.js und unterstützt die Entwicklung der Vollstapel.

Die Rolle von C/C bei JavaScript -Dolmetschern und CompilernDie Rolle von C/C bei JavaScript -Dolmetschern und CompilernApr 20, 2025 am 12:01 AM

C und C spielen eine wichtige Rolle in der JavaScript -Engine, die hauptsächlich zur Implementierung von Dolmetschern und JIT -Compilern verwendet wird. 1) C wird verwendet, um JavaScript -Quellcode zu analysieren und einen abstrakten Syntaxbaum zu generieren. 2) C ist für die Generierung und Ausführung von Bytecode verantwortlich. 3) C implementiert den JIT-Compiler, optimiert und kompiliert Hot-Spot-Code zur Laufzeit und verbessert die Ausführungseffizienz von JavaScript erheblich.

JavaScript in Aktion: Beispiele und Projekte in realer WeltJavaScript in Aktion: Beispiele und Projekte in realer WeltApr 19, 2025 am 12:13 AM

Die Anwendung von JavaScript in der realen Welt umfasst Front-End- und Back-End-Entwicklung. 1) Zeigen Sie Front-End-Anwendungen an, indem Sie eine TODO-Listanwendung erstellen, die DOM-Operationen und Ereignisverarbeitung umfasst. 2) Erstellen Sie RESTFUFFUPI über Node.js und express, um Back-End-Anwendungen zu demonstrieren.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.