Heim >Web-Frontend >js-Tutorial >Beispiel für die Javascript-Implementierung einer asynchronen Bild-Upload-Methode

Beispiel für die Javascript-Implementierung einer asynchronen Bild-Upload-Methode

小云云
小云云Original
2017-12-06 11:07:111638Durchsuche

Wie schreibe ich einen asynchronen Bild-Upload über Javascript? In diesem Artikel stellen wir Ihnen einige Javascript-Beispielcodes zur Implementierung des asynchronen Bild-Uploads vor. Schauen 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>


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();


FormData lädt Dateien asynchron hoch


<input type="file" id="file">


1. Erstellen Fügen Sie FormData in die hochzuladende Datei ein


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


2. Senden Sie FormData-Daten über xhr an den Server, um den Datei-Upload durchzuführen


//创建xhr对象
var xhr = new XMLHttpRequest();

//监听文件上传进度
xhr.upload.onprogress = function(evt){
 //lengthComputabel: 文件长度是否可计算
 if(evt.lengthComputable){
  //evt.loaded: 已下载的字节数
  //evt.total: 文件总字节数
  var percent = Math.round(evt.loaded*100/evt.total);
  console.log(percent);
 }
}

//监听文件传输开始 
xhr.onloadstart = function(evt){
  xhr.abort() //终止上传
}

//监听ajax成功完成事件
xhr.onload = function(evt){
 ...
}

//监听ajax错误事件 
xhr.onerror = function(evt){
 ...
}

//监听ajax被中止事件
xhr.onabort = function(evt){
 ...
}

//监听传输结束事件: 不管成功或者失败都会触发
xhr.onloaded = function(evt){
 ...
}
 
//*发起ajax请求数据
xhr.open(&#39;POST&#39;, &#39;/url&#39;, true);
xhr.send(formData);

Der obige Inhalt ist ein Beispiel für eine asynchrone Bild-Upload-Methode in JavaScript. Ich hoffe, dass er allen helfen kann.

Verwandte Empfehlungen:

php+js-Implementierung des asynchronen Hochladens von Bildern, Beispielfreigabe

JavaScript verwendet FileReader, um die Bild-Upload- und Vorschaufunktion abzuschließen Einführung

Detaillierte Erläuterung der Implementierung eines einfachen Bild-Upload-Codes in node.js

Das obige ist der detaillierte Inhalt vonBeispiel für die Javascript-Implementierung einer asynchronen Bild-Upload-Methode. 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