使用原生HTML5上传文件

最近碰到个需求,需要使用js上传文件,一般上传文件都是使用表单,并为使用过js上传,这次在这记录一下。

     之前网上说使用jquery插件jqueryajaxupload.js。用下来发现坑巨多,果断舍弃,换用原生的HTML5来做上传。具体思想就是创建一个FormData对象,将file标签的值设进formdata对象里面去,再使用xmlhttprequest上传,同时在xhr中添加监听器获取回调


代码如下:

function uploadFile() {
		var fd = new FormData();
		fd.append('fileType', 2);
		fd.append("file", $('#diverCeriticate')[0].files[0]);
		var xhr = new XMLHttpRequest();
		//xhr.upload.addEventListener("progress", uploadProgress, false);
		xhr.addEventListener("load", uploadComplete, false);
		xhr.addEventListener("error", uploadFailed, false);
		xhr.open("POST", UPLOAD_FILE_URL);
		
		xhr.send(fd);
		}
		function uploadComplete(e) {
		//e.target.responseText 为上传结果
		var json = JSON.stringify(JSON.parse(e.target.responseText), null,'');
		
		alert("json"+json);
		}
		
		function uploadFailed(e) {
			alert(e);
			}
		





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值