Heim Web-Frontend js-Tutorial Ajax-Fortschrittsbalken-Download-Implementierungsbeispielcode basierend auf Blod

Ajax-Fortschrittsbalken-Download-Implementierungsbeispielcode basierend auf Blod

May 22, 2018 pm 04:46 PM
ajax 下载

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>
Nach dem Login kopieren

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;;
Nach dem Login kopieren

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});
  }
}
Nach dem Login kopieren

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);
}
Nach dem Login kopieren

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!

Erklärung dieser Website
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

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

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So laden Sie Episoden des Hongguo-Kurzdramas herunter So laden Sie Episoden des Hongguo-Kurzdramas herunter Mar 11, 2024 pm 09:16 PM

Hongguo Short Play ist nicht nur eine Plattform zum Ansehen von Kurzstücken, sondern auch eine Fundgrube an reichhaltigen Inhalten, darunter Romane und andere spannende Inhalte. Für viele lesebegeisterte Nutzer ist das zweifellos eine große Überraschung. Viele Benutzer wissen jedoch immer noch nicht, wie sie diese Romane in Hongguo Short Play herunterladen und ansehen können. Im Folgenden stellt Ihnen der Herausgeber dieser Website detaillierte Download-Schritte vor, in der Hoffnung, allen bedürftigen Partnern zu helfen. Wie kann ich das Hongguo-Kurzspiel herunterladen und ansehen? Antwort: [Hongguo-Kurzspiel] – [Hörbuch] – [Artikel] – [Download]. Spezifische Schritte: 1. Öffnen Sie zuerst die Hongguo Short Drama-Software, rufen Sie die Startseite auf und klicken Sie oben auf der Seite auf die Schaltfläche [Bücher anhören]. 2. Dann können wir hier auf der Romanseite viele Artikelinhalte sehen

Was soll ich tun, wenn ich das Hintergrundbild einer anderen Person herunterlade, nachdem ich mich bei WallpaperEngine bei einem anderen Konto angemeldet habe? Was soll ich tun, wenn ich das Hintergrundbild einer anderen Person herunterlade, nachdem ich mich bei WallpaperEngine bei einem anderen Konto angemeldet habe? Mar 19, 2024 pm 02:00 PM

Wenn Sie sich auf Ihrem Computer beim Steam-Konto einer anderen Person anmelden und das Konto dieser anderen Person über eine Hintergrundsoftware verfügt, lädt Steam automatisch die Hintergrundbilder herunter, die für das Konto der anderen Person abonniert wurden, nachdem Sie zu Ihrem eigenen Konto zurückgewechselt haben Deaktivieren der Steam-Cloud-Synchronisierung. Was tun, wenn WallpaperEngine die Hintergrundbilder anderer Personen herunterlädt, nachdem Sie sich bei einem anderen Konto angemeldet haben? 1. Melden Sie sich bei Ihrem eigenen Steam-Konto an, suchen Sie in den Einstellungen nach der Cloud-Synchronisierung und deaktivieren Sie die Steam-Cloud-Synchronisierung. 2. Melden Sie sich bei dem Steam-Konto einer anderen Person an, bei dem Sie sich zuvor angemeldet haben, öffnen Sie den Wallpaper Creative Workshop, suchen Sie nach den Abonnementinhalten und kündigen Sie dann alle Abonnements. (Falls Sie das Hintergrundbild in Zukunft nicht mehr finden, können Sie es zunächst abholen und dann das Abonnement kündigen.) 3. Wechseln Sie zurück zu Ihrem eigenen Steam

Wie lade ich Links herunter, die mit 115:// beginnen? Methodeneinführung herunterladen Wie lade ich Links herunter, die mit 115:// beginnen? Methodeneinführung herunterladen Mar 14, 2024 am 11:58 AM

In letzter Zeit haben viele Benutzer den Editor gefragt, wie man Links herunterlädt, die mit 115:// beginnen? Wenn Sie Links herunterladen möchten, die mit 115:// beginnen, müssen Sie den 115-Browser verwenden. Nachdem Sie den 115-Browser heruntergeladen haben, schauen wir uns das unten vom Herausgeber zusammengestellte Download-Tutorial an. Einführung zum Herunterladen von Links, die mit 115:// beginnen. 1. Melden Sie sich bei 115.com an, laden Sie den 115-Browser herunter und installieren Sie ihn. 2. Geben Sie Folgendes ein: chrome://extensions/ in die Adressleiste des 115-Browsers, rufen Sie das Extension Center auf, suchen Sie nach Tampermonkey und installieren Sie das entsprechende Plug-in. 3. Geben Sie in die Adressleiste des Browsers 115 ein: Grease Monkey Script: https://greasyfork.org/en/

Einführung in das Herunterladen und Installieren des Superpeople-Spiels Einführung in das Herunterladen und Installieren des Superpeople-Spiels Mar 30, 2024 pm 04:01 PM

Das Superpeople-Spiel kann über den Steam-Client heruntergeladen werden. Die Größe dieses Spiels beträgt normalerweise eineinhalb Stunden. Hier ist ein spezielles Download- und Installations-Tutorial. Neue Methode zur Beantragung globaler geschlossener Tests 1) Suchen Sie nach „SUPERPEOPLE“ im Steam-Store (Steam-Client-Download) 2) Klicken Sie unten auf der „SUPERPEOPLE“-Store-Seite auf „Zugriff auf geschlossene SUPERPEOPLE-Tests anfordern“ 3) Nachdem Sie auf geklickt haben Schaltfläche „Zugriff anfordern“. Das Spiel „SUPERPEOPLECBT“ kann in der Steam-Bibliothek bestätigt werden. 4) Klicken Sie auf die Schaltfläche „Installieren“ in „SUPERPEOPLECBT“ und laden Sie es herunter

Wie lade ich eine Quark-Netzwerkfestplatte lokal herunter? So speichern Sie von Quark Network Disk heruntergeladene Dateien wieder auf dem lokalen Computer Wie lade ich eine Quark-Netzwerkfestplatte lokal herunter? So speichern Sie von Quark Network Disk heruntergeladene Dateien wieder auf dem lokalen Computer Mar 13, 2024 pm 08:31 PM

Viele Benutzer müssen Dateien herunterladen, wenn sie Quark Network Disk verwenden, aber wir möchten sie lokal speichern. Wie richtet man das also ein? Auf dieser Website erfahren Sie ausführlich, wie Sie von Quark Network Disk heruntergeladene Dateien wieder auf dem lokalen Computer speichern. So speichern Sie von der Quark-Netzwerkfestplatte heruntergeladene Dateien wieder auf Ihrem lokalen Computer 1. Öffnen Sie Quark, melden Sie sich bei Ihrem Konto an und klicken Sie auf das Listensymbol. 2. Nachdem Sie auf das Symbol geklickt haben, wählen Sie das Netzwerklaufwerk aus. 3. Nachdem Sie Quark Network Disk aufgerufen haben, klicken Sie auf „Meine Dateien“. 4. Nachdem Sie „Meine Dateien“ aufgerufen haben, wählen Sie die Datei aus, die Sie herunterladen möchten, und klicken Sie auf das Dreipunktsymbol. 5. Markieren Sie die Datei, die Sie herunterladen möchten, und klicken Sie auf Herunterladen.

Mar 18, 2024 am 10:58 AM

foobar2000 ist eine Software, die Ihnen jederzeit Musik aller Art mit verlustfreier Klangqualität bietet Spielen Sie das erweiterte Audio auf dem Computer ab, um ein bequemeres und effizienteres Musikwiedergabeerlebnis zu ermöglichen. Das Interface-Design ist einfach, klar und benutzerfreundlich. Es nimmt einen minimalistischen Designstil an, ohne übermäßige Dekoration Es unterstützt außerdem eine Vielzahl von Skins und Themes, personalisiert Einstellungen nach Ihren eigenen Vorlieben und erstellt einen exklusiven Musikplayer, der die Wiedergabe mehrerer Audioformate unterstützt. Außerdem unterstützt es die Audio-Gain-Funktion zum Anpassen der Lautstärke Passen Sie die Lautstärke entsprechend Ihrem Hörzustand an, um Hörschäden durch zu hohe Lautstärke zu vermeiden. Als nächstes lass mich dir helfen

Wo kann man Dateien von Quark Network Disk herunterladen_So laden Sie Quark Network Disk in den lokalen Bereich herunter und teilen ihn Wo kann man Dateien von Quark Network Disk herunterladen_So laden Sie Quark Network Disk in den lokalen Bereich herunter und teilen ihn Mar 21, 2024 pm 03:57 PM

Als praktisches und praktisches Tool für Netzwerkfestplatten kann Quark Benutzern dabei helfen, ihre bevorzugten Ressourcen einfach abzurufen. Was ist, wenn Sie eine Datei lokal herunterladen möchten? Lassen Sie sich jetzt vom Redakteur erzählen, lernen wir es gemeinsam! So laden Sie Quark Network Disk zur lokalen Freigabe herunter: 1. Öffnen Sie zunächst die Quark-Software, rufen Sie die Startseite auf und klicken Sie auf das [Cloud-Symbol] unten rechts. 2. Klicken Sie dann auf der Quark Network Disk-Seite auf die Funktion [Dokument]. 3. Gehen Sie dann zur Dokumentseite, wählen Sie die Datei aus, die Sie herunterladen möchten, und klicken Sie auf das [Drei-Punkte-Symbol] 4. Nach dem letzten Klick klicken wir im Popup-Dialogfeld auf [Herunterladen].

So laden Sie Beilehu-Kinderlieder herunter So laden Sie Beilehu-Kinderlieder herunter Mar 28, 2024 am 11:10 AM

Als unverzichtbare Begleitung für das Wachstum von Kindern haben Beilehus Kinderlieder mit ihrer fröhlichen Melodie, ihren lebendigen Bildern und ihrem unterhaltsamen und lehrreichen Inhalt die Liebe unzähliger Eltern und Kinder gewonnen. Damit Babys jederzeit und überall die Freude an Kinderliedern genießen können, hoffen viele Eltern, die Kinderlieder von Beilehu auf ihr Mobiltelefon oder Tablet herunterzuladen, damit sie ihren Kindern jederzeit zuhören können. Aber wie können die Kinderlieder von Beilehu gespeichert werden? ? Auf Ihrem Mobiltelefon erhalten Sie eine detaillierte Einführung. Benutzer, die es noch nicht verstehen, können diesen Artikel mitlesen, um mehr zu erfahren. Beilehu-Kinderlieder-Tutorial mit mehreren Bildern: Öffnen Sie die Software und wählen Sie ein Kinderlied aus, das Sie herunterladen möchten. 2. Klicken Sie auf die Schaltfläche „Herunterladen“ unter dem Kinderlied-Stern.

See all articles