js实现文件上传功能 后台使用MultipartFile


Posted in Javascript onSeptember 08, 2018

本文为大家分享了js实现文件上传功能的具体代码,供大家参考,具体内容如下

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>XMLHttpRequest上传文件</title>
  <script type="text/javascript">
    //图片上传
    var xhr;
    //上传文件方法
    function UpladFile() {
      var fileObj = document.getElementById("file").files[0]; // js 获取文件对象
      var url = "http://localhost:8080" + "/api/attachment/upload"; // 接收上传文件的后台地址
 
      var form = new FormData(); // FormData 对象
      form.append("file", fileObj); // 文件对象
 
      xhr = new XMLHttpRequest(); // XMLHttpRequest 对象
      xhr.open("post", url, true); //post方式,url为服务器请求地址,true 该参数规定请求是否异步处理。
      xhr.onload = uploadComplete; //请求完成
      xhr.onerror = uploadFailed; //请求失败
 
      xhr.upload.onprogress = progressFunction;//【上传进度调用方法实现】
      xhr.upload.onloadstart = function(){//上传开始执行方法
        ot = new Date().getTime();  //设置上传开始时间
        oloaded = 0;//设置上传开始时,以上传的文件大小为0
      };
 
      xhr.send(form); //开始上传,发送form数据
    }
 
    //上传成功响应
    function uploadComplete(evt) {
      //服务断接收完文件返回的结果
 
      var data = JSON.parse(evt.target.responseText);
      if(data.success) {
        alert("上传成功!");
      }else{
        alert("上传失败!");
      }
 
    }
    //上传失败
    function uploadFailed(evt) {
      alert("上传失败!");
    }
    //取消上传
    function cancleUploadFile(){
      xhr.abort();
    }
 
 
    //上传进度实现方法,上传过程中会频繁调用该方法
    function progressFunction(evt) {
      var progressBar = document.getElementById("progressBar");
      var percentageDiv = document.getElementById("percentage");
      // event.total是需要传输的总字节,event.loaded是已经传输的字节。如果event.lengthComputable不为真,则event.total等于0
      if (evt.lengthComputable) {//
        progressBar.max = evt.total;
        progressBar.value = evt.loaded;
        percentageDiv.innerHTML = Math.round(evt.loaded / evt.total * 100) + "%";
      }
      var time = document.getElementById("time");
      var nt = new Date().getTime();//获取当前时间
      var pertime = (nt-ot)/1000; //计算出上次调用该方法时到现在的时间差,单位为s
      ot = new Date().getTime(); //重新赋值时间,用于下次计算
      var perload = evt.loaded - oloaded; //计算该分段上传的文件大小,单位b
      oloaded = evt.loaded;//重新赋值已上传文件大小,用以下次计算
      //上传速度计算
      var speed = perload/pertime;//单位b/s
      var bspeed = speed;
      var units = 'b/s';//单位名称
      if(speed/1024>1){
        speed = speed/1024;
        units = 'k/s';
      }
      if(speed/1024>1){
        speed = speed/1024;
        units = 'M/s';
      }
      speed = speed.toFixed(1);
      //剩余时间
      var resttime = ((evt.total-evt.loaded)/bspeed).toFixed(1);
      time.innerHTML = ',速度:'+speed+units+',剩余时间:'+resttime+'s';
      if(bspeed==0) time.innerHTML = '上传已取消';
    }
  </script>
</head>
<body>
<progress id="progressBar" value="0" max="100" style="width: 300px;"></progress>
<span id="percentage"></span><span id="time"></span>
<br /><br />
<input type="file" id="file" name="myfile" />
<input type="button" onclick="UpladFile()" value="上传" />
<input type="button" onclick="cancleUploadFile()" value="取消" />
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
推荐自用 Javascript 缩图函数 (onDOMLoaded)……
Oct 23 Javascript
File, FileReader 和 Ajax 文件上传实例分析(php)
Apr 27 Javascript
jquery中ajax函数执行顺序问题之如何设置同步
Feb 28 Javascript
js delete 用法(删除对象属性及变量)
Aug 24 Javascript
jQuery实现弹出窗口中切换登录与注册表单
Jun 05 Javascript
在JavaScript中操作数组之map()方法的使用
Jun 09 Javascript
JS实现随页面滚动显示/隐藏窗口固定位置元素
Feb 26 Javascript
简单谈谈JS中的正则表达式
Sep 11 Javascript
js实现1,2,3,5数字按照概率生成
Sep 12 Javascript
vue下使用nginx刷新页面404的问题解决
Aug 02 Javascript
js实现开关灯效果
Mar 30 Javascript
JavaScript实现鼠标经过表格某行时此行变色
Nov 20 Javascript
vue-router的HTML5 History 模式设置
Sep 08 #Javascript
vue移动端下拉刷新和上拉加载的实现代码
Sep 08 #Javascript
react 父子组件之间通讯props
Sep 08 #Javascript
js代码规范之Eslint安装与配置详解
Sep 08 #Javascript
vue弹窗插件实战代码
Sep 08 #Javascript
浅谈从React渲染流程分析Diff算法
Sep 08 #Javascript
详解Webpack-dev-server的proxy用法
Sep 08 #Javascript
You might like
php,不用COM,生成excel文件
2006/10/09 PHP
JoshChen_web格式编码UTF8-无BOM的小细节分析
2013/08/16 PHP
php实现加减法验证码代码
2014/02/14 PHP
PHP实现的英文名字全拼随机排号脚本
2014/07/04 PHP
PHP生成短网址的思路以及实现方法的详解
2019/03/25 PHP
彪哥1.1(智能表格)提供下载
2006/09/07 Javascript
javascript不同页面传值的改进版
2008/09/30 Javascript
原生javascript和jquery判断浏览器版本等信息
2013/07/04 Javascript
jQuery插件expander实现图片翻转特效
2015/05/21 Javascript
如何提高数据访问速度
2016/12/26 Javascript
jQuery实现checkbox的简单操作
2017/11/18 jQuery
小程序绑定用户方案优化小结
2019/05/15 Javascript
vue 开发之路由配置方法详解
2019/12/02 Javascript
Vue Render函数创建DOM节点代码实例
2020/07/08 Javascript
JavaScript大数相加相乘的实现方法实例
2020/10/18 Javascript
[15:20]DOTA2-DPC中国联赛 正赛 Elephant vs Aster 选手采访
2021/03/11 DOTA
Python实现建立SSH连接的方法
2015/06/03 Python
分析python请求数据
2018/08/19 Python
python根据文本生成词云图代码实例
2019/11/15 Python
python不相等的两个字符串的 if 条件判断为True详解
2020/03/12 Python
用python制作个音乐下载器
2021/01/30 Python
canvas 下载二维码和图片加水印的方法
2018/03/21 HTML / CSS
Sneaker Studio法国:购买运动鞋
2018/06/08 全球购物
俄罗斯茶和咖啡网上商店:Tea.ru
2021/01/26 全球购物
2013年大学生的自我鉴定
2013/10/24 职场文书
毕业生求职找工作的自我评价范文
2013/11/27 职场文书
协议书与合同的区别
2014/04/18 职场文书
教师纪念9.18事件演讲稿范文
2014/09/14 职场文书
2015年政府采购工作总结
2015/05/21 职场文书
2015年语文教学工作总结
2015/05/25 职场文书
公司客户答谢酒会祝酒词
2015/08/11 职场文书
教师个人工作总结范文2015
2015/10/14 职场文书
新入职员工工作总结
2015/10/15 职场文书
2016三严三实专题教育活动心得体会
2016/01/06 职场文书
Android Canvas绘制文字横纵向对齐
2022/06/05 Java/Android
MySQL导致索引失效的几种情况
2022/06/25 MySQL