>웹 프론트엔드 >JS 튜토리얼 >비동기 이미지 업로드 방법의 자바스크립트 구현 예

비동기 이미지 업로드 방법의 자바스크립트 구현 예

小云云
小云云원래의
2017-12-06 11:07:111591검색

자바스크립트를 통해 비동기 이미지 업로드를 작성하는 방법은 무엇입니까? 이 기사에서는 비동기 이미지 업로드를 구현하기 위한 몇 가지 예제 코드 자바스크립트를 공유하겠습니다. 먼저 HTML 코드로 구현된 폼 제출 부분을 살펴보겠습니다. 테스트할 때 테스트 URL을 자신의 URL로 바꾸거나 로컬 주소를 직접 작성하여 테스트할 수 있습니다.

html 코드:


<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 코드:


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 비동기식으로 파일 업로드


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


1. FormData를 생성하고 업로드할 파일을 넣습니다.


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


2. 파일 업로드를 구현하기 위해 xhr을 통해 FormData 데이터를 서버로 보냅니다


//创建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);

위 내용은 자바스크립트의 비동기 이미지 업로드 방법의 예입니다. 모두에게 도움이 되기를 바랍니다. .

관련 권장사항:

php+js 비동기 이미지 업로드 예제 공유 구현

JavaScript는 FileReader를 사용하여 이미지 업로드 및 미리보기 기능 소개 완료

node.js가 간단한 이미지 업로드 코드를 구현하는 방법에 대한 자세한 설명

위 내용은 비동기 이미지 업로드 방법의 자바스크립트 구현 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.