温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

js如何实现文件上传功能

发布时间:2021-04-20 10:32:08 来源:亿速云 阅读:1552 作者:小新 栏目:web开发

小编给大家分享一下js如何实现文件上传功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

js有什么特点

1、js属于一种解释性脚本语言;2、在绝大多数浏览器的支持下,js可以在多种平台下运行,拥有着跨平台特性;3、js属于一种弱类型脚本语言,对使用的数据类型未做出严格的要求,能够进行类型转换,简单又容易上手;4、js语言安全性高,只能通过浏览器实现信息浏览或动态交互,从而有效地防止数据的丢失;5、基于对象的脚本语言,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" ></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>

以上是“js如何实现文件上传功能”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

js
AI