ajax--上传进度条


选择文件后就上传,并有进度条显示上传进度

	<style type="text/css">
	#big{
		width: 500px;
		height: 30px;
		border: 1px solid grey;
	}
	#sm{
		width: 0%;
		height: 30px;
		background: grey;
	}
	</style>

</head>
<body>
<div id="big">
	<div id="sm"></div>
</div>
	<input type="file" name="pic" οnchange="upload()">
</body>

bigdiv是进度条的外框

smalldiv是内部行走的进度条



<script type="text/javascript">
	function upload(){
			var pic=document.getElementsByName('pic')[0].files[0];
			var fd = new FormData();
			fd.append('file',pic);
			var xhr=new XMLHttpRequest();	
			xhr.open('POST','8file.php',true);
/*进度条需要2个最基础的信息
总大小 已上传大小

html5
有上传过程事件 onprogress
能读到这两个

在send之前
利用xhr2新标准 为上传过程写一个监听函数
*/

			xhr.upload.onprogress = function(ev){
				if(ev.lengthComputable){
					var percent = 100*ev.loaded/ev.total;
					// console.log(percent);
					// 进度条div的长度随percent增加而增加
					document.getElementById('sm').style.width=percent + '%';
					document.getElementById('sm').innerHTML = percent + '%';
				}
			}
			// 发送
			xhr.send(fd);

			}

	</script>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值