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

자바스크립트에서 비동기 이미지 업로드를 구현하는 방법

亚连
풀어 주다: 2018-06-22 16:37:03
원래의
1398명이 탐색했습니다.

Javascript를 통해 비동기 이미지 업로드를 작성하는 방법을 자세히 설명하고 관심 있는 독자가 테스트할 수 있도록 예제 코드를 공유합니다.

먼저 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. 파일 업로드를 위해 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);
로그인 후 복사
위에서 모두를 위해 정리했습니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

키 알파벳 순서로 단일 레이어 json 정렬을 구현하는 방법(자세한 튜토리얼)

Thinkjs3에서 정적 리소스 디렉터리를 사용하는 방법

JsonObject의 키-값 데이터 구문 분석 및 정렬 정보 (자세한 튜토리얼)

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

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿