Heim > Web-Frontend > js-Tutorial > Hauptteil

So implementieren Sie den asynchronen Bild-Upload in Javascript

亚连
Freigeben: 2018-06-22 16:37:03
Original
1348 Leute haben es durchsucht

Ich werde ausführlich erklären, wie man einen asynchronen Bild-Upload über Javascript schreibt, und den Beispielcode mit Ihnen teilen, der ihn testen kann.

Sehen wir uns zunächst den Teil der Formularübermittlung an, der durch HTML-Code implementiert wird. Beim Testen müssen Sie die Test-URL durch Ihre eigene ersetzen oder direkt eine lokale Adresse zum Testen schreiben.

HTML-Code:

<form id="uploadForm" action="http://storage.test.com/file/upload" method="post" enctype="multipart/form-data">
  <input type="hidden" name="key" id="key" value="VTZ18HM64#D_L3WX" />
  <input type="file" name="uploadFiles" value="" id="fileImage" multiple=&#39;multiple&#39; />
  <p class="upload_submit">
  <button type="button" id="fileSubmit" class="upload_btn">保存</button>
  </p>
</form>
Nach dem Login kopieren

JS-Code:

var Fileupload = {
  fileInput: $("#fileImage").get(0),
  dragDrop: $("#fileDragArea").get(0),
  upButton: $("#fileSubmit").get(0),
  url: $("#uploadForm").attr("action"),
  })(),
  //文件上传
  funUploadFile: function() {
   var self = this;
   for (var i = 0, file; file = this.fileFilter[i]; i++) {
    (function(file) {
     var xhr = new XMLHttpRequest();
     if (xhr.upload) {
      // 上传中
      xhr.upload.addEventListener("progress", function(e) {
       self.onProgress(file, e.loaded, e.total);
      }, false);
      // 文件上传成功或是失败
      xhr.onreadystatechange = function(e) {

      if (xhr.readyState == 4) {
        if (xhr.status == 200) {
         self.onSuccess(JSON.parse(xhr.responseText));
         self.funDeleteFile(file);
         if (!self.fileFilter.length) {
          //全部完毕
          self.onComplete();
         }
        } else {
         self.onFailure(file, xhr.responseText);
        }
       }
      };
      //准备FormData对象
      var myForm = document.getElementById(&#39;uploadForm&#39;);
      //将文件放入FormData对象中
      formData = new FormData(myForm);

      // 开始上传
      xhr.open("POST", self.url, true);
      xhr.send(formData);
     }
    })(file);
   }
  },
  init: function() {
   var self = this;
   //上传按钮提交
   if (this.upButton) {
    console.log(&#39;提示: 当前存储服务器地址&#39;, this.url)
    this.upButton.addEventListener("click", function(e) {
     self.funUploadFile(e);
    }, false);
   }
   self.bindEvent();
  }
 };
 Fileupload = $.extend(Fileupload);
 Fileupload.init();
Nach dem Login kopieren

FormData lädt Dateien asynchron hoch

<input type="file" id="file">
Nach dem Login kopieren

1. Erstellen Sie FormData und legen Sie die hochzuladende Datei ab

//准备FormData对象
var formData = new FormData(),
 uploadFile = document.getElementById(&#39;file&#39;);
 
//将文件放入FormData对象中 
formData.append(&#39;file&#39;, uploadFile.files[0]);
Nach dem Login kopieren

2. FormData-Daten an den Server senden über

Verwandte Artikel:

So implementieren Sie eine einschichtige JSON-Sortierung in alphabetischer Schlüsselreihenfolge (ausführliches Tutorial)

So verwenden Sie Statik im Thinkjs3-Ressourcenverzeichnis

Informationen zum Parsen und Sortieren von Schlüsselwertdaten in JsonObject (ausführliches Tutorial)

Das obige ist der detaillierte Inhalt vonSo implementieren Sie den asynchronen Bild-Upload in Javascript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!