该上传功能主要用到html5新属性FormData,通过XMLHttpRequest对象send到服务器,支持文件多选和多次选择、文件去重、移除已选文件等

1、html代码

      <div class="formtitle upLoad">附件上传</div>
<div class="chooseFile" style="height: auto;">
<input type="button" id="uploadbtn" value="选择文件..." /><input type="button" id="uploadfile" style="display: none;" value="上传文件" />
<input type="file" id="uploadpicker" accept="" style="display: none;" multiple />
<div>
<ul id="checkfileList"></ul>
</div>
</div>

  

2、javascript 代码

    var selectedFileList = [];//已选文件列表
var paramTaskId = "";//请求参数
var succsessCount = 0;//上传成功文件个数
var errorCount = 0;//上传失败文件个数
$(function () {
$("#uploadbtn").bind("click", function (e) {
$("#uploadpicker").click();
});
$("#uploadpicker").bind("change", function () {//绑定文件选择事件
var files = $("#uploadpicker").prop("files");
$.each(files, function (index, item) {
var choiseFile = $("#checkfileList>li");
if (choiseFile.length > 0) {//文件去重
var count = 0;
$.each(choiseFile, function (index1, item1) {
if (item.name == item1.innerText) {
count++;
}
});
if (count == 0) {
if (checkFileLength(item.size)) {
$("#checkfileList").append("<li class=\"fileinfo\">" + item.name + "<a style=\"display: none; color: red; margin-left: 10px;\" href=\"javascript:void(0)\" onclick=\"RemoveFile(this)\">删除</a>" + "</li>");
selectedFileList.push(item);
AddMoushover();
}
}
} else {
if (checkFileLength(item.size)) {
$("#checkfileList").append("<li class=\"fileinfo\">" + item.name + "<a style=\"display: none; color: red; margin-left: 10px;\" href=\"javascript:void(0)\" onclick=\"RemoveFile(this)\">删除</a>" + "</li>");
selectedFileList.push(item);
AddMoushover();
}
}
});
});
AddMoushover();
});
//判断文件是否超过限制大小
function checkFileLength(fileLen) {
if (fileLen > 4194304) {
$.messager.alert("提示", "上传文件大小不能超过4M","error");
return false;
}
return true;
}
//上传文件
function uploadFile() {
if (selectedFileList.length>0) {
$.messager.progress({
title: "提示",
msg: "文件上传中..."
});
$.each(selectedFileList, function (index, item) {
debugger;
var dataform = new FormData();
dataform.append("file", item);
var xmlhttp = null;
if (window.XMLHttpRequest) {// code for all new browsers
xmlhttp = new XMLHttpRequest();
}
else if (window.ActiveXObject) {// code for IE5 and IE6
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
if (xmlhttp != null) {
xmlhttp.open("POST", "/Project/ProjectTask/SaveFiles?TaskId=" + paramTaskId, true);
xmlhttp.send(dataform);
xmlhttp.onreadystatechange = callbackMethods;
} else {
alert("你的浏览器版本不兼容,请使用更高版本的浏览器");
}
//请求回调函数
function callbackMethods() {
debugger;
if (xmlhttp.readyState == 4) {
if (xmlhttp.status == 200) {
succsessCount++;
if ((succsessCount + errorCount) == selectedFileList.length) {
if (errorCount > 0) {
$.messager.alert("提示", "上传文件完成," + errorCount + "个文件由于过大上传失败。", "error");
}
submitSuccess();
}
} else {
if (xmlhttp.status==500) {
errorCount++;
if ((succsessCount + errorCount) == selectedFileList.length) {
if (errorCount>0) {
$.messager.alert("提示", "上传文件完成,"+errorCount+"个文件由于过大上传失败。", "error");
}
submitSuccess();
}
}
}
}
}
}); } else {
submitSuccess();
}
}
//移除已选择的文件
function RemoveFile(obj) {
$.messager.confirm("提示", "确认删除当前文件?", function(e) {
if (e) {
var index = $("#checkfileList>li").index($(obj).parent());
selectedFileList.splice(index, 1);
$(obj).parent().remove();
}
});
}
//添加鼠标经过事件,鼠标划过时显示“删除”
function AddMoushover() {
$(".fileinfo").hover(function () {
$(this).find("a").last().css("display", "");
}, function () {
$(this).find("a").last().css("display", "none");
});
}

  3、图片展示

javascript实现简单多文件上传的更多相关文章

  1. 服务器文档下载zip格式 SQL Server SQL分页查询 C#过滤html标签 EF 延时加载与死锁 在JS方法中返回多个值的三种方法(转载) IEnumerable,ICollection,IList接口问题 不吹不擂,你想要的Python面试都在这里了【315+道题】 基于mvc三层架构和ajax技术实现最简单的文件上传 事件管理

    服务器文档下载zip格式   刚好这次项目中遇到了这个东西,就来弄一下,挺简单的,但是前台调用的时候弄错了,浪费了大半天的时间,本人也是菜鸟一枚.开始吧.(MVC的) @using Rattan.Co ...

  2. 使用jsp/servlet简单实现文件上传与下载

    使用JSP/Servlet简单实现文件上传与下载    通过学习黑马jsp教学视频,我学会了使用jsp与servlet简单地实现web的文件的上传与下载,首先感谢黑马.好了,下面来简单了解如何通过使用 ...

  3. Django 实现简单的文件上传

    今天分享一下Django实现的简单的文件上传的小例子. 步骤 创建Django项目,创建Django应用 设计模型 处理urls.py 以及views.py 设计模板,设计表单 运行项目,查看数据库 ...

  4. DVWA靶机--简单的文件上传漏洞

    简单的文件上传漏洞(靶机安全级别:low) 事先准备好一句话木马,密码为pass 上传一句话木马,显示上传路径(一般网站是不会显示路径的,这里靶机为了方便你测试漏洞,直接显示出了路径: ../../h ...

  5. Java实现一个简单的文件上传案例

    Java实现一个简单的文件上传案例 实现流程: 1.客户端从硬盘读取文件数据到程序中 2.客户端输出流,写出文件到服务端 3.服务端输出流,读取文件数据到服务端中 4.输出流,写出文件数据到服务器硬盘 ...

  6. javascript插件uploadify简单实现文件上传

    最近在学习mvc,需要用到文件上传的功能,找了很多的jquery插件,最后决定使用uploadify这个插件,参照了各位大神的博客,终于勉勉强强会用了.在此,做一下笔记,方便以后忘了查看. 首先在官网 ...

  7. 使用 JavaScript File API 实现文件上传

    概述 以往对于基于浏览器的应用而言,访问本地文件都是一件头疼的事情.虽然伴随着 Web 2.0 应用技术的不断发展,JavaScript 正在扮演越来越重要的角色,但是出于安全性的考虑,JavaScr ...

  8. java 网络编程之TCP通信和简单的文件上传功能

    */ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...

  9. struts2中简单的文件上传

    2016-08-31 一.       文件上传 利用commons-fileupload-1.2.1.jar实现简单的上传文件,首先在页面上填写表单,记得加上enctype="multip ...

随机推荐

  1. 关于javascript中apply()和call()方法的区别

    如果没接触过动态语言,以编译型语言的思维方式去理解javaScript将会有种神奇而怪异的感觉,因为意识上往往不可能的事偏偏就发生了,甚至觉得不可理喻.如果在学JavaScript这自由而变幻无穷的语 ...

  2. 2016-2017-2《程序设计与数据结构》学生博客&git@OSC

    2016-2017-2<程序设计与数据结构>学生博客&git@OSC 博客园 20162301张师瑜 20162302杨京典 20162303石亚鑫 20162304张浩林 201 ...

  3. C#进阶系列——MEF实现设计上的“松耦合”(四):构造函数注入

    前言:今天十一长假的第一天,本因出去走走,奈何博主最大的乐趣是假期坐在电脑前看各处堵车,顺便写写博客,有点收获也是好的.关于MEF的知识,之前已经分享过三篇,为什么有今天这篇?是因为昨天分享领域服务的 ...

  4. jinfo_动态调整JVM参数(无需重启)(实践)

    ​本文演示在JVM进程运行过程中动态开启/关闭 GC输出,无需重启JVM进程 jinfo使用介绍 可以用来查看正在运行的Java应用程序的扩展参数,甚至支持在运行时,修改部分参数 -flag < ...

  5. 【BZOJ 4561】【JLOI 2016】圆的异或并

    http://www.lydsy.com/JudgeOnline/problem.php?id=4561 一开始并不会做,后来看题解看懂了. 看懂了之后还是错了好几次,数组大小手残开小了. 圆的包含并 ...

  6. 解决:MIUI 8应用商店下载不了软件 APP

    MIUI 8应用商店下载不了软件,是什么原因呢? 原因是:刷了国际版的MIUI,然后又刷回国内的MIUI,刷机时数据没有清理干净. 解决办法:使用RE管理器或者其他第三方可以编辑系统文件的文件管理器, ...

  7. [UOJ30/Codeforces Round #278 E]Tourists

    传送门 好毒瘤的一道题QAQ,搞了好几好几天. UOJ上卡在了53个点,CF上过了,懒得优化常数了 刚看时一眼Tarjan搞个强连通分量然后缩点树链剖分xjb搞搞就行了,然后写完了,然后WA了QAQ. ...

  8. php 错误

    ini_set('display_errors', '1');error_reporting(E_ALL ^ E_NOTICE);   有时有了其它框架 应该用它的配置,要不然,你改了,它又改回去了: ...

  9. Examples of MIB Variables - SNMP Tutorial

    30.5 Examples of MIB Variables Versions 1 and 2 of SNMP each collected variables together in a singl ...

  10. Jquery动态添加的元素绑定事件的3种方法

    假设我们点击li标签,弹出他的文本,如果是动态添加的li,点击是没有效果的,压根弹不出来文本. 下面博主分享一下为动态添加的元素绑定事件的三种方法,网上一般都是两种,我在这里多增加了一种. 事件案例: ...