Ajax上传文件进度条显示

1
2
3
4
要实现进度条的显示,就要知道两个参数,上传的大小和总文件的大小
html5提供了一个上传过程事件,在上传过程中不断触发,然后用已上传的大
小/总大小,计算上传的百分比,然后用这个百分比控制div框的显示,就可以
实现上传的进度条效果


前端页面

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Ajax上传文件进度条显示</title>
<script type="text/javascript">
function upfile(){
    var pic=document.getElementsByTagName('input')[0].files[0];
    var fd=new FormData();
    var xhr=new XMLHttpRequest();
    xhr.open('post','01.php',true);
    xhr.onreadystatechange=function (){
        if(this.readyState==4){
            document.getElementById('precent').innerHTML=this.responseText;
        }
    }
    xhr.upload.onprogress=function (ev){
        //console.log(ev);控制台打印progress { target: XMLHttpRequestUpload, isTrusted: true, lengthComputable: true,<br> //loaded: 15020, total: 15020, eventPhase: 0, bubbles: false, cancelable: false, defaultPrevented: false, <br>//timeStamp: 1445144855459000, originalTarget: XMLHttpRequestUpload }
        if(ev.lengthComputable){
            var precent=100 * ev.loaded/ev.total;
            console.log(precent);
            document.getElementById('nei').style.width=precent+'%';
            document.getElementById('precent').innerHTML=Math.floor(precent)+'%';
        }
    }
    fd.append('pic',pic);
     
    xhr.send(fd);
     
}
</script>
<style>
#wai{
width:500px;
height:30px;
border:1px solid green;
}
#nei{
width:0px;
height:30px;
background:green;
}
</style>
</head>
<body>
    <div id="wai">
        <div id="nei"></div>
    </div><span id="precent"></span><br/>
    <input type="file" name="pic" onchange="upfile();"/>
</body>
</html>

 页面显示效果

posted @   飘逸110  阅读(7129)  评论(0编辑  收藏  举报
编辑推荐:
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
阅读排行:
· DeepSeek 解答了困扰我五年的技术问题。时代确实变了!
· PPT革命!DeepSeek+Kimi=N小时工作5分钟完成?
· What?废柴, 还在本地部署DeepSeek吗?Are you kidding?
· DeepSeek企业级部署实战指南:从服务器选型到Dify私有化落地
· 程序员转型AI:行业分析
点击右上角即可分享
微信分享提示