实例讲解javascript实现异步图片上传方法


Posted in Javascript onDecember 05, 2017

我们首先看下HTML代码实现的form提交部分。其中大家在测试的时候需要把test的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='multiple' />
  <div class="upload_submit">
  <button type="button" id="fileSubmit" class="upload_btn">保存</button>
  </div>
</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('uploadForm');
      //将文件放入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('提示: 当前存储服务器地址', 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">

一、创建FormData放入待上传文件

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

二、通过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('POST', '/url', true);
xhr.send(formData);
Javascript 相关文章推荐
JS对img进行操作(换图片/切图/轮换/停止)
Apr 17 Javascript
jquery.validate.js插件使用经验记录
Jul 02 Javascript
jquery中map函数遍历数组用法实例
May 18 Javascript
简介alert()与console.log()的不同
Aug 26 Javascript
JS+JSP通过img标签调用实现静态页面访问次数统计的方法
Dec 14 Javascript
jQuery实现元素的插入
Feb 27 Javascript
利用Three.js如何实现阴影效果实例代码
Sep 26 Javascript
JS动态添加的div点击跳转到另一页面实现代码
Sep 30 Javascript
js中document.write和document.writeln的区别
Mar 11 Javascript
详解CommonJS和ES6模块循环加载处理的区别
Dec 26 Javascript
详解基于webpack&amp;gettext的前端多语言方案
Jan 29 Javascript
vue中node_modules中第三方模块的修改使用详解
May 31 Javascript
jquery如何实现点击空白处隐藏元素
Dec 05 #jQuery
jQuery实现验证表单密码一致性及正则表达式验证邮箱、手机号的方法
Dec 05 #jQuery
最实用的JS数组函数整理
Dec 05 #Javascript
微信小程序picker组件简单用法示例【附demo源码下载】
Dec 05 #Javascript
Vue DevTools调试工具的使用
Dec 05 #Javascript
Vue 项目部署到服务器的问题解决方法
Dec 05 #Javascript
webpack学习教程之前端性能优化总结
Dec 05 #Javascript
You might like
后宫无数却洁身自好的男主,唐三只爱小舞
2020/03/02 国漫
延长phpmyadmin登录时间的方法
2011/02/06 PHP
本地计算机无法启动Apache故障处理
2014/08/08 PHP
Thinkphp搭建包括JS多语言的多语言项目实现方法
2014/11/24 PHP
php字符串截取函数用法分析
2014/11/25 PHP
php源码分析之DZX1.5加密解密函数authcode用法
2015/06/17 PHP
PHP 对象继承原理与简单用法示例
2020/04/21 PHP
JavaScript实现Sleep函数的代码
2007/03/04 Javascript
window.open不被拦截的实现代码
2012/08/22 Javascript
鼠标经过tr时,改变tr当前背景颜色
2014/01/13 Javascript
angular简介和其特点介绍
2015/01/29 Javascript
详解JavaScript时间处理之几个月前或几个月后的指定日期
2016/12/21 Javascript
jquery实现拖动效果(代码分享)
2017/01/25 Javascript
vue mint-ui 实现省市区街道4级联动示例(仿淘宝京东收货地址4级联动)
2017/10/16 Javascript
全面介绍vue 全家桶和项目实例
2017/12/27 Javascript
jQuery幻灯片插件owlcarousel参数说明中文文档
2018/02/27 jQuery
浅谈js中的bind
2019/03/18 Javascript
vue轮播组件实现$children和$parent 附带好用的gif录制工具
2019/09/26 Javascript
一篇文章看懂JavaScript中的回调
2021/01/05 Javascript
[00:26]TI7不朽珍藏III——冥界亚龙不朽展示
2017/07/15 DOTA
Python计算三角函数之asin()方法的使用
2015/05/15 Python
浅谈Python2获取中文文件名的编码问题
2018/01/09 Python
python过滤中英文标点符号的实例代码
2019/07/15 Python
如何基于python操作json文件获取内容
2019/12/24 Python
通过Python实现Payload分离免杀过程详解
2020/07/13 Python
css3中单位px,em,rem,vh,vw,vmin,vmax的区别及浏览器支持情况
2016/12/06 HTML / CSS
Wojas罗马尼亚网站:波兰皮鞋品牌
2018/11/01 全球购物
巴塞罗那观光通票:Barcelona Pass
2019/10/30 全球购物
个人找工作自荐信格式
2013/09/21 职场文书
中专生职业生涯规划书范文
2014/01/10 职场文书
大学学雷锋活动总结
2014/06/26 职场文书
在宿舍喝酒的检讨书
2014/09/28 职场文书
理想国读书笔记
2015/06/25 职场文书
婚前协议书怎么写,才具有法律效力呢 ?
2019/06/28 职场文书
死磕 java同步系列之synchronized解析
2021/06/28 Java/Android
java实现web实时消息推送的七种方案
2022/07/23 Java/Android