当前访客身份:游客 [ 登录 | 加入 OSCHINA ]

代码分享

当前位置:
代码分享 » JavaScript  » 网页设计与交互
分享到: 
收藏 +0
1
本代码是文章 http://www.oschina.net/bbs/thread/15544 的配套示例
标签: 文件上传

代码片段(2) [全屏查看所有代码]

1. [文件] sourcecode.zip ~ 3KB     下载(528)     [全屏预览]

2. [代码][JavaScript]代码     跳至 [2] [全屏预览]

function addDNDListeners(){
	var container = document.getElementById("container");
	var fileList = document.getElementById("fileList");
	container.addEventListener("dragenter", function(event){
		fileList.innerHTML ='';
		event.stopPropagation();
		event.preventDefault();
		}, false);
	container.addEventListener("dragover", function(event){
		event.stopPropagation();
		event.preventDefault();
		}, false);
	container.addEventListener("drop", handleDrop, false);
}
function handleDrop(event){
	var files = event.dataTransfer.files;
	event.stopPropagation();
	event.preventDefault();
	
	var fileList = document.getElementById("fileList");
	for (var i = 0; i < files.length; i++) {
		var file = files[i];
		var li = document.createElement('li');
		var progressbar = document.createElement('div');
		var img = document.createElement('img');
		var name = document.createElement('span');
		
		progressbar.className = "progressBar";
		img.src = files[i].getAsDataURL();
		img.width = 32;
		img.height = 32;					
		name.innerHTML = file.name;
		li.appendChild(img);			
		li.appendChild(name);
		li.appendChild(progressbar);
							
		fileList.appendChild(li);
		uploadFile(file, progressbar)
	}
}
function uploadFile(file, progressbar) {
	var xhr = new XMLHttpRequest();
	var	upload = xhr.upload;
	
	var p = document.createElement('p');
	p.textContent = "0%";
	progressbar.appendChild(p);
				
	upload.progressbar = progressbar;				
	upload.addEventListener("progress", uploadProgress, false);
	upload.addEventListener("load", uploadSucceed, false);
	upload.addEventListener("error", uploadError, false);

	xhr.open("POST", "upload.jsp?fileName="+file.name);
	xhr.overrideMimeType("application/octet-stream");
	xhr.sendAsBinary(file.getAsBinary());
}
function uploadProgress(event){				
	if (event.lengthComputable) {
		var percentage = Math.round((event.loaded * 100) / event.total);
		console.log("percentage:" + percentage);
		if (percentage < 100) {
			event.target.progressbar.firstChild.style.width = (percentage*2) + "px";
			event.target.progressbar.firstChild.textContent = percentage + "%";
		}
	}
}
function uploadSucceed(event) {
	event.target.progressbar.firstChild.style.width = "200px";
	event.target.progressbar.firstChild.textContent = "100%";
}			
function uploadError(error) {
	alert("error: " + error);
}
window.addEventListener("load", addDNDListeners, false);


开源中国-程序员在线工具:Git代码托管 API文档大全(120+) JS在线编辑演示 二维码 更多»

发表评论 回到顶部 网友评论(4)

  • 1楼:答复哈 发表于 2011-02-12 09:26 回复此评论
    头一回发现Javascript还能异步上传文件.
  • 2楼:浮生如斯 发表于 2013-08-21 09:09 回复此评论
    xhr.sendAsBinary(file.getAsBinary());
    这句你测试了吗,浏览器都不太支持的。
    一般上传还要用FileReader在给他转一下,读取成二进制数据在给后台发过去的。。
  • 3楼:霡霂 发表于 2013-10-28 16:06 回复此评论

    引用来自“浮生如斯”的评论

    xhr.sendAsBinary(file.getAsBinary());
    这句你测试了吗,浏览器都不太支持的。
    一般上传还要用FileReader在给他转一下,读取成二进制数据在给后台发过去的。。
    reader = new FileReader(); reader.readAsBinaryString(file/*获取的文件引用,也就是上文中的file*/) xhr.sendAsBinary(reader.result);//通过result就能处理文件的二进制。
  • 4楼:霡霂 发表于 2013-10-28 16:50 回复此评论
    悲剧了。
    sendAsBinary貌似只有在火狐下才有,Chrome下不支持。
开源从代码分享开始 分享代码