原生JavaScript实现异步多文件上传


Posted in Javascript onDecember 02, 2015

这是在上篇的修改版本。后台代码不变就可以接着使用,但是脚本不再使用jQuery了,改为原生的JavaScript 代码,所以我们主要看JS代码。

先介绍一下技术参数:

页面技术:HTML5

后台技术:Servlet 3.0

服务器:Tomcat 7.0

脚本:JavaScript

HTML5 file组件的新属性

accept : 如果在file组件中增加这个属性就可以直接控制上传的文件类型了,实在是很方便。

multiple:是否允许选择多个文件
HTML5 页面代码修改后

<img width="400" height="250"/><br />
<input type="file" id="pic" name="pic" onchange="printFileInfo()" accept="image/*" multiple="multiple"/>
<input type="button" value="上传图片" onclick="uploadFile()" /><br />
<div id="parent">
<div id="son"></div>
</div>

accept 的值可以参阅:IANA MIME 类型(标准 MIME 类型的完整列表),如果使用的是DW开发的话,软件本身就有提示。

如果选择了多个文件,可以用JS做循环打印,看看文件的名称,类型和大小,看演示代码

function printFileInfo(){
 
 var picFile = document.getElementById("pic"); 
 var files = picFile.files;
 for(var i=0; i<files.length; i++){
  var file = files[i];
  var div = document.createElement("div")
  div.innerHTML = "第("+ (i+1) +") 个文件的名字:"+ file.name +
  " , 文件类型:"+ file.type +" , 文件大小:"+ file.size 
  document.body.appendChild( div)
 }
}

既然可以循环多文件的话,就可以尝试多文件上传了。

1、首先创建 XMLHttpRequest 对象

//这是全局变量。因为是示例,所以就没有判断浏览器类型,低版本IE这么写的话会出问题的
var xhr = new XMLHttpRequest()
2、上篇介绍了进度事件(Progress) , 这次实现 progress 和 error 2个事件

error:在请求发生错误时触发。

 对应上传时发生错误导致的上传失败:uploadFailed()

//上传失败
function uploadFailed(evt) {
 alert("上传失败");
}
progress:在接收相应期间持续不断触发。




对应上传进度方法:onprogress()
/**
 * 侦查附件上传情况 ,这个方法大概0.05-0.1秒执行一次
 */
function onprogress(evt){
 var loaded = evt.loaded;       //已经上传大小情况 
 var tot = evt.total;       //附件总大小 
 var per = Math.floor(100*loaded/tot);   //已经上传的百分比 
  $("#son").html( per +"%" );
 $("#son").css("width" , per +"%");
}

最后就是上传方法了,注意上面的html代码中上传用的方法也需要改成这个uploadFile()方法才能正常使用。

//上传文件
function uploadFile() {
//将上传的多个文件放入formData中
 var picFileList = $("#pic").get(0).files;
 var formData = new FormData();
 for(var i=0; i< picFileList.length; i++){
  formData.append("file" , picFileList[i] );
 }

 //监听事件
 xhr.upload.addEventListener("progress", onprogress, false);
 xhr.addEventListener("error", uploadFailed, false);//发送文件和表单自定义参数
 xhr.open("POST", "upload");
 //记得加入上传数据formData

 xhr.send(formData);
}

PS: 这毕竟只是基本功能的演示示例,离公司使用的要求还相差十万八千里,请谨慎在公司平台使用。

大家可以结合这篇文章进行学习:基于HTML5 Ajax文件上传进度条如何实现(jquery版本)

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
IE8下String的Trim()方法失效的解决方法
Nov 08 Javascript
jquery进行数组遍历如何跳出当前的each循环
Jun 05 Javascript
JavaScript字符串对象
Jan 14 Javascript
移动端刮刮乐的实现方式(js+HTML5)
Mar 23 Javascript
Ajax验证用户名或昵称是否已被注册
Apr 05 Javascript
weebox弹出窗口不居中显示的解决方法
Nov 27 Javascript
Three.js 再探 - 写一个微信跳一跳极简版游戏
Jan 04 Javascript
在vue组件中使用axios的方法
Mar 16 Javascript
JS重学系列之聊聊new操作符
Mar 04 Javascript
Koa日志中间件封装开发详解
Mar 09 Javascript
微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析
Aug 16 Javascript
Vue实现随机验证码功能
Dec 29 Vue.js
Jquery 1.9.1源码分析系列(十二)之筛选操作
Dec 02 #Javascript
日常收藏的jquery技巧
Dec 02 #Javascript
JavaScript使用DeviceOne开发实战(三)仿微信应用
Dec 02 #Javascript
jquery密码强度校验
Dec 02 #Javascript
基于jQuery实现的双11天猫拆红包抽奖效果
Dec 01 #Javascript
jquery实现全选、反选、获得所有选中的checkbox
Sep 13 #Javascript
js实现继承的5种方式
Dec 01 #Javascript
You might like
PHP网页游戏学习之Xnova(ogame)源码解读(二)
2014/06/23 PHP
php+ajax无刷新上传图片实例代码
2015/11/17 PHP
PHP使用Memcache时模拟命名空间及缓存失效问题的解决
2016/02/27 PHP
Yii2验证器(Validator)用法分析
2016/07/23 PHP
如何通过PHP实现Des加密算法代码实例
2020/05/09 PHP
contains和compareDocumentPosition 方法来确定是否HTML节点间的关系
2011/09/13 Javascript
jQuery 一个图片切换的插件
2011/10/09 Javascript
JavaScript 学习笔记之基础中的基础
2015/01/13 Javascript
pace.js页面加载进度条插件
2015/09/29 Javascript
JavaScript创建对象的七种方式全面总结
2017/08/21 Javascript
Angular实现双向折叠列表组件的示例代码
2017/11/21 Javascript
JavaScript原生实现观察者模式的示例
2017/12/15 Javascript
Vue项目分环境打包的实现步骤
2018/04/02 Javascript
bootstrap-table实现表头固定以及列固定的方法示例
2019/03/07 Javascript
利用百度echarts实现图表功能简单入门示例【附源码下载】
2019/06/10 Javascript
layer 关闭指定弹出层的例子
2019/09/25 Javascript
javascript局部自定义鼠标右键菜单
2020/12/08 Javascript
TensorFlow Session使用的两种方法小结
2018/07/30 Python
python 搭建简单的http server,可直接post文件的实例
2019/01/03 Python
Pandas统计重复的列里面的值方法
2019/01/30 Python
python3实现指定目录下文件sha256及文件大小统计
2019/02/25 Python
浅谈python之高阶函数和匿名函数
2019/03/21 Python
Django 自定义分页器的实现代码
2019/11/24 Python
Python实现不规则图形填充的思路
2020/02/02 Python
德国最大的设计师鞋网上商店:Budapester
2017/12/07 全球购物
应届生人事助理求职信
2013/11/09 职场文书
经典大学生求职信范文
2014/01/06 职场文书
高中化学教学反思
2014/01/13 职场文书
大学总结自我鉴定
2014/01/18 职场文书
财务信息服务专业自荐书范文
2014/02/08 职场文书
学校社会实践活动总结
2014/07/03 职场文书
2015年基层党组织公开承诺书
2015/01/21 职场文书
《观潮》教学反思
2016/02/17 职场文书
2019 入党申请书范文
2019/07/10 职场文书
Django 如何实现文件上传下载
2021/04/08 Python
微信小程序基础教程之echart的使用
2021/06/01 Javascript