HTML5中Ajax如何实现文件上传并显示进度条
短信预约 -IT技能 免费直播动态提醒
这篇文章主要介绍HTML5中Ajax如何实现文件上传并显示进度条,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
具体内容如下
效果图:
html5上传是同步上传的方式,所以能够实现进度条的显示。
1.上传文件:
首先我们用ajax来取得<input type="file" id="file_upload">的file对象:
var file = null; var input = $("#file_upload"); //文件域选择文件时, 执行readFile函数 input.addEventListener('change',readFile,false); function readFile(){ file = this.files[0]; }
然后用FormData()送到后台。
var fd = new FormData(); fd.append("file", file);
2.监听事件:给XMLHttpRequest添加上传中的监听事件,可以得到已上传的文件大小,用以实现进度条的显示。
//监听事件 hr.upload.addEventListener("progress", uploadProgress, false);
完整代码如下:
<html> <head> <meta charset="utf-8"> <title>进度条测试</title> <script type="text/javascript" class="lazy" data-src="../js/jquery-1.11.1.min.js"></script> </head> <body> <input type="file" id="file_upload"/> <input type="button" value="上传" id="upload"/> <div > <div id="progressNumber" > </div> </div> <font id="percent">0%</font> </body> <script> var file = null; $(function(){ $("#upload").click(function(){ upload(); }); }); var input = document.getElementById("file_upload"); //文件域选择文件时, 执行readFile函数 input.addEventListener('change',readFile,false); function readFile(){ file = this.files[0]; } //上传文件 function upload(){ var xhr = new XMLHttpRequest(); var fd = new FormData(); fd.append("fileName", file); //监听事件 xhr.upload.addEventListener("progress", uploadProgress, false); //发送文件和表单自定义参数 xhr.open("POST", "../UploadServlet",true); xhr.send(fd); } function uploadProgress(evt){ if (evt.lengthComputable) { //evt.loaded:文件上传的大小 evt.total:文件总的大小 var percentComplete = Math.round((evt.loaded) * 100 / evt.total); //加载进度条,同时显示信息 $("#percent").html(percentComplete + '%') $("#progressNumber").css("width",""+percentComplete+"px"); } } </script> </html>
什么是ajax
ajax是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术,可以通过在后台与服务器进行少量数据交换,使网页实现异步更新。
以上是“HTML5中Ajax如何实现文件上传并显示进度条”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341