html5 图片上传进度条,使用Html5实现异步上传文件,支持跨域,带有上传进度条

服务器准备IIS

需要设置IIS里面的HTTP响应标头,如图添加如下设置,添加这项“Access-Control-Allow-Origin”,只有添加了这行才能支持跨域,不然像Chrome浏览器会报错

页面代码:

XML/HTML Code复制内容到剪贴板

Html5上传文件

Html5上传文件测试,带进度条

function fileSelected() {

//重置状态显示

document.getElementById("msg").innerHTML = "";

document.getElementById('percentNumber').innerHTML = '';

document.getElementById("progress").style.width = "0%";

var file = document.getElementById('fileInput').files[0];

if (file) {

var fileSize = 0;

if (file.size > 1024 * 1024)

fileSize = (Math.round(file.size * 100 / (1024 * 1024)) / 100).toString() + 'MB';

else

fileSize = (Math.round(file.size * 100 / 1024) / 100).toString() + 'KB';

document.getElementById('fileName').innerHTML = 'Name: ' + file.name;

document.getElementById('fileSize').innerHTML = 'Size: ' + fileSize;

document.getElementById('fileType').innerHTML = 'Type: ' + file.type;

}

}

function uploadFile() {

var fd = new FormData();

fd.append("fileInput", document.getElementById('fileInput').files[0]);

var xhr = new XMLHttpRequest();

xhr.upload.addEventListener("progress", uploadProgress, false);

xhr.addEventListener("load", uploadComplete, false);

xhr.addEventListener("error", uploadFailed, false);

xhr.addEventListener("abort", uploadCanceled, false);

xhr.open("POST", "http://10.0.0.200:9001/Home/Upload");//修改为自己服务器接口地址

//xhr.setRequestHeader("Access-Control-Allow-Origin", "*");//需要在IIS里面配置,就可以跨域请求了

//xhr.setRequestHeader("Content-Type", "multipart/form-data");

xhr.send(fd);

}

function uploadProgress(evt) {

if (evt.lengthComputable) {

var percentComplete = Math.round(evt.loaded * 100 / evt.total);

document.getElementById('percentNumber').innerHTML = percentComplete + '%';

var jindutiao = document.getElementById("progress");

jindutiao.style.width = percentComplete + "%";

}

else {

document.getElementById('percentNumber').innerHTML = '不支持进度计算';

}

}

function uploadComplete(evt) {

//evt.target.responseText

document.getElementById("msg").innerHTML = "上传成功";

}

function uploadFailed(evt) {

document.getElementById("msg").innerHTML = "上传过程中有一个错误";

}

function uploadCanceled(evt) {

document.getElementById("msg").innerHTML = "用户取消了上传或者浏览器删除了连接";

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值