Input表单写法:

<input type="file" multiple="multiple" accept="image/jpeg" name="newPhoto" value="" id="newPhoto">
multiple选项用于声明是批量上传 accept声明只接收jpg格式的图片,其他格式的文件在选项卡中显示不出来


来自:http://www.cnblogs.com/kissdodog/archive/2012/12/15/2819025.html

一、ajaxFileUpload是一个异步上传文件的jQuery插件。

传一个不知道什么版本的上来,以后不用到处找了。

语法:$.ajaxFileUpload([options])

options参数说明:

1、url           上传处理程序地址。  
2,fileElementId      需要上传的文件域的ID,即<input type="file">的ID。
3,secureuri        是否启用安全提交,默认为false。
4,dataType        服务器返回的数据类型。可以为xml,script,json,html。如果不填写,jQuery会自动判断。
5,success        提交成功后自动执行的处理函数,参数data就是服务器返回的数据。
6,error          提交失败自动执行的处理函数。
7,data          自定义参数。这个东西比较有用,当有数据是与上传的图片相关的时候,这个东西就要用到了。
8,type           当要提交自定义参数时,这个参数要设置成post

错误提示:

1,SyntaxError: missing ; before statement错误
  如果出现这个错误就需要检查url路径是否可以访问
2,SyntaxError: Syntax error错误
  如果出现这个错误就需要检查处理提交操作的服务器后台处理程序是否存在语法错误
3,SyntaxError: invalid property id错误
  如果出现这个错误就需要检查文本域属性ID是否存在
4,SyntaxError: missing } in XML expression错误
  如果出现这个错误就需要检查文件name是否一致或不存在
5,其它自定义错误
  大家可使用变量$error直接打印的方法检查各参数是否正确,比起上面这些无效的错误提示还是方便很多。

使用方法:

引入jQuery与ajaxFileUpload插件。注意先后顺序,这个不用说了,所有的插件都是这样。

 <script src="jquery-1.7.1.js" type="text/javascript"></script>
 <script src="ajaxfileupload.js" type="text/javascript"></script>

一个例子:

<html>
<head>
    <script src="/jquery-1.7.1.js" type="text/javascript"></script>
    <script src="/ajaxfileupload.js" type="text/javascript"></script>
    <script type="text/javascript">
        $(function () {
            $(":button").click(function () {
                if ($("#file1").val().length > 0) {
                    ajaxFileUpload();
                }
                else {
                    alert("请选择图片");
                }
            })
        })
        function ajaxFileUpload() {
            $.ajaxFileUpload
            (
                {
                    url: '/Home/Upload',//用于文件上传的服务器端请求地址
                    secureuri: false,//一般设置为false
                    fileElementId: 'file1',//文件上传空间的id属性  <input type="file" id="file" name="file" />
                    dataType: 'HTML',//返回值类型 一般设置为json
                    success: function (data,status)  //服务器成功响应处理函数
                    {
                        alert(data);
                        $("#img1").attr("src",data);
                        if (typeof (data.error) != 'undefined') {
                            if (data.error != '') {
                                alert(data.error);
                            } else {
                                alert(data.msg);
                            }
                        }
                    },error: function (data,status,e)//服务器响应失败处理函数
                    {
                        alert(e);
                    }
                }
            )
            return false;
        }
    </script>
</head>
<body>
    <p><input type="file" id="file1" name="file" /></p>
    <input type="button" value="上传" />
    <p><img id="img1" alt="上传成功啦" src="" /></p>
</body>
</html>

我的批量上传: ajaxFileUpload插件原理其实构建了一个表单form,里面很多file用于上传:最后submit()表单:见下面部分源码
var form = jQuery('<form  action="" method="POST" name="'+ formId + '" id="' + formId
	+ '" enctype="multipart/form-data"></form>');
if (data) {
	for ( var i in data) {
		jQuery('<input type="hidden" name="' + i + '" value="'
			+ data[i] + '" />').appendTo(form);
	}
}


提交函数:

function uploadHeadPhoto(){
	var userId = $("#userId",navTab.getCurrentPanel()).val();;
	if (userId == null) {
		alertMsg.error("请选择用户ID");   //dwz框架
		return;
	}
	
	//必须上传图片,才能注册
	var newHeadPhoto = $("#newPhoto",navTab.getCurrentPanel()).val();
	if (newHeadPhoto != null && newHeadPhoto != '') {
		if (newHeadPhoto.toLowerCase().indexOf('.jpg') < 0) {
			alertMsg.error("请上传JPG文件");
			return;
		};
	} else {
		alertMsg.error('请添加头像照片');
		return;
	}
	
	var albumId = $("#albumId",navTab.getCurrentPanel()).val();
	if (albumId == null || albumId=='') {
		alertMsg.error("头像所属相册编号为空");
		return;
	}
	//加载缓冲效果
	//对应html页面的:<img id="loading" src="../images/loading.gif" style="display:none; width: 17px;">
	$("#loading",navTab.getCurrentPanel()).ajaxStart(function() {
		$(this).show();
	}).ajaxComplete(function() {
		$(this).hide();
	});
	$.ajaxFileUpload({
		url : 'uploadMultiHeadPhoto.do',//服务器url
		data : {
			"albumId" : albumId,"userId" : userId
		},secureuri : false,fileElementId : 'newPhoto',dataType : 'json',success : function(data,status) {
			var photoList = eval("(" + data.message + ")");
			var additionalRecord = '';
			//将解析出来的图像上传后的url,上传状态做显示
			for(var i=0 ;i<photoList.length;i++){
				var record = "<img src='" + photoList[i].photoName + "' alt='" + photoList[i].id + "' id='headPhoto" + photoList[i].id +
				"' onclick='selectHeadPhoto(this," + photoList[i].id +")' />";
				additionalRecord += record;
			}
			//加载到该显示的地方
			var headPhotoListTD=$("#headPhotoList",navTab.getCurrentPanel());
			var orignalRecord = headPhotoListTD.html();
			headPhotoListTD.html(orignalRecord + additionalRecord);
		},error : function(data,e) {
			alertMsg.info(e);
		}
	});
}


SpringMVC框架后台接收:
    @RequestMapping(value = "uploadMultiHeadPhoto.do")
    @ResponseBody
    public AjaxResponseBean uploadMultiHeadPhoto(
    		@modelattribute("userInfoBean") UserInfoBean userBean,HttpServletRequest request,HttpServletResponse response,ModelMap map) {

UserInfoBean:
private List<multipartfile> newPhoto;

保存图片到本地并返回List<File>
public static List<File> saveFileList(List<multipartfile> multipartfiles,String parent,String extend) throws Exception {
	List<File> files  = new ArrayList<>();
	if(parent == null){
		// 保存文件的父目录
		parent = makeParentDirectory();
	}
	if (multipartfiles == null ||  multipartfiles.size()<=0) {
		return null;
	}
	
	for(multipartfile multipartfile : multipartfiles){
		String originalFilename = multipartfile.getoriginalFilename();
	if(StringUtil.isNotBlank(originalFilename)){
		int index = originalFilename.lastIndexOf(".");
		if(index > 0){
			extend = originalFilename.substring(index);
		}
	}
	// 生成一个随机数,保证同一时间 也不会生成相同的文件名
	int temp = (int)Math.random() *1000;
	String fileName = MD5.getMD5(originalFilename + temp + DateUtil.datetoString(new Date(),Format.YYYY_MM_DD_HH_MM_SS_SSS));
	String savePath = parent +File.separator + fileName + extend;
		File localFile = new File(savePath);
		try {
			multipartfile.transferTo(localFile);
			files.add(localFile);
		} catch (IllegalStateException e) {
			throw e;
		} catch (IOException e) {
			throw e;
		}
	}
	return files;
}

可以将List<File>再上传到图片服务器

ajax批量上传的更多相关文章

  1. canvas中普通动效与粒子动效的实现代码示例

    canvas用于在网页上绘制图像、动画,可以将其理解为画布,在这个画布上构建想要的效果。本文详细的介绍了粒子特效,和普通动效进行对比,非常具有实用价值,需要的朋友可以参考下

  2. H5混合开发app如何升级的方法

    本篇文章主要介绍了H5混合开发app如何升级的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  3. canvas学习和滤镜实现代码

    这篇文章主要介绍了canvas学习和滤镜实现代码,利用 canvas,前端人员可以很轻松地、进行图像处理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  4. localStorage的过期时间设置的方法详解

    这篇文章主要介绍了localStorage的过期时间设置的方法详解的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  5. 详解HTML5 data-* 自定义属性

    这篇文章主要介绍了详解HTML5 data-* 自定义属性的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  6. HTML5的postMessage的使用手册

    HTML5提出了一个新的用来跨域传值的方法,即postMessage,这篇文章主要介绍了HTML5的postMessage的使用手册的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  7. 教你使用Canvas处理图片的方法

    本篇文章主要介绍了教你使用Canvas处理图片的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  8. ios – Swift语言:如何调用SecRandomCopyBytes

    从Objective-C,我可以这样做:在Swift中尝试这个时,我有以下内容:但我得到这个编译器错误:data.mutableBytes参数被拒绝,因为类型不匹配,但我无法弄清楚如何强制参数.解决方法这似乎有效:

  9. 使用Firebase iOS Swift将特定设备的通知推送到特定设备

    我非常感谢PushNotifications的帮助.我的应用聊天,用户可以直接向对方发送短信.但是如果没有PushNotifications,它就没有多大意义.它全部设置在Firebase上.如何将推送通知从特定设备发送到特定设备?

  10. ios – NSData to Data swift 3

    如何将此代码转换为使用Swift3数据?

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部