jQuery异步上传文件插件ajaxFileUpload详细介绍

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

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

语法:$.ajaxFileUpload([options])

options参数说明:

1、url           上传处理程序地址。   2,fileElementId      需要上传文件域的ID,即默认为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插件。注意先后顺序,这个不用说了,所有的插件都是这样。

代码如下:

第四步:后台页面upload.aspx代码

代码如下:
0) { files[0].SaveAs(Server.MapPath("/") + System.IO.Path.GetFileName(files[0].FileName)); msg = " 成功! 文件大小为:" + files[0].ContentLength; imgurl = "/" + files[0].FileName; string res = "{ error:'" + error + "',msg:'" + msg + "',imgurl:'" + imgurl + "'}"; Response.Write(res); Response.End(); } }

本实例

来一个MVC版本的实例:

控制器代码

代码如下:

public ActionResult Upload() { HttpFileCollection hfc = System.Web.HttpContext.Current.Request.Files; string imgPath = ""; if (hfc.Count > 0) { imgPath = "/testUpload" + hfc[0].FileName; string PhysicalPath = Server.MapPath(imgPath); hfc[0].SaveAs(PhysicalPath); } return Content(imgPath); } }

前端视图,HTML与JS代码,成功上传后,返回图片真实地址并绑定到的SRC地址

代码如下:

上传成功啦

最后再来一个上传图片且附带参数的实例:控制器代码

代码如下:

public ActionResult Upload() { NameValueCollection nvc = System.Web.HttpContext.Current.Request.Form;

HttpFileCollection hfc = System.Web.HttpContext.Current.Request.Files; string imgPath = ""; if (hfc.Count > 0) { imgPath = "/testUpload" + hfc[0].FileName; string PhysicalPath = Server.MapPath(imgPath); hfc[0].SaveAs(PhysicalPath); } //注意要写好后面的第二第三个参数 return Json(new { Id = nvc.Get("Id"),name = nvc.Get("name"),imgPath1 = imgPath },"text/html",JsonRequestBehavior.AllowGet); } }

Index视图代码:

代码如下:

上传成功啦

此实例在显示出异步上传图片的同时并弹出自定义传输的参数。本实例

2013年1月28日,今天调试过程中发现一个问题,就是作为文件域(属性,如果没有name属性上传之后服务器是获取不到图片的。如:正确的写法是

2013年1月28日,最经典的错误终于找到原因所在了。Object function (a,b){return new e.fn.init(a,b,h)} has no method 'handleError',这个是google浏览器报的错误,非常经典, 不知道是我的版本问题还是真正存在的问题。这个问题的根源经过N次上传才找到问题的根本所在。答案是:dataType参数一定要大写。如:dataType: 'HTML'。

相关文章

IE6是一个非常老旧的网页浏览器,虽然现在很少人再使用它,但...
PHP中的count()函数是用来计算数组或容器中元素的个数。这个...
使用 AJAX(Asynchronous JavaScript and XML)技术可以在不...
Ajax(Asynchronous JavaScript and XML)是一种用于改进网页...
本文将介绍如何通过AJAX下载Excel文件流。通过AJAX,我们可以...
Ajax是一种用于客户端和服务器之间的异步通信技术。通过Ajax...