全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

jQuery插件ajaxFileUpload使用详解

ajaxFileUpload.js 很多同名的,因为做出来一个很容易。

我用的是这个:https://github.com/carlcarl/AjaxFileUpload

下载地址在这里:http://xiazai./201701/yuanma/ajaxfileupload().rar

AjaxFileUpload.js并不是一个很出名的插件,只是别人写好的放出来供大家用,原理都是创建隐藏的表单和iframe然后用JS去提交,获得返回值。

当初做了个异步上传的功能,选择它因为它的配置方式比较像jQuery的AJAX,我很喜欢。

评论里面说到的不行。那是因为我们用的不是同一个js。我上github搜AjaxFileUpload出来很多类似js。

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代码:

<body>
 <p><input type="file" id="file1" name="file" /></p>
 <input type="button" value="上传" />
 <p><img id="img1" alt="上传成功啦" src="" /></p>
</body>

第三步:JS代码

 <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 () {
 ajaxFileUpload();
 })
 })
 function ajaxFileUpload() {
 $.ajaxFileUpload
 (
 {
  url: '/upload.aspx', //用于文件上传的服务器端请求地址
  secureuri: false, //是否需要安全协议,一般设置为false
  fileElementId: 'file1', //文件上传域的ID
  dataType: 'json', //返回值类型 一般设置为json
  success: function (data, status) //服务器成功响应处理函数
  {
  $("#img1").attr("src", data.imgurl);
  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>

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

 protected void Page_Load(object sender, EventArgs e)
 {
 HttpFileCollection files = Request.Files;
 string msg = string.Empty;
 string error = string.Empty;
 string imgurl;
 if (files.Count > 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 class HomeController : Controller
 {
 public ActionResult Index()
 {
 return View();
 }

 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代码,成功上传后,返回图片真实地址并绑定到<img>的SRC地址

<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>

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

 public class HomeController : Controller
 {
 public ActionResult Index()
 {
 return View();
 }

 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视图代码:

<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', //用于文件上传的服务器端请求地址
  type: 'post',
  data: { Id: '123', name: 'lunis' }, //此参数非常严谨,写错一个引号都不行
  secureuri: false, //一般设置为false
  fileElementId: 'file1', //文件上传空间的id属性 <input type="file" id="file" name="file" />
  dataType: 'json', //返回值类型 一般设置为json
  success: function (data, status) //服务器成功响应处理函数
  {
  alert(data);
  $("#img1").attr("src", data.imgPath1);
  alert("你请求的Id是" + data.Id + " " + "你请求的名字是:" + data.name);
  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>

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

  2013年1月28日,今天调试过程中发现一个问题,就是作为文件域(<input type="file">)必须要有name属性,如果没有name属性,上传之后服务器是获取不到图片的。如:正确的写法是<input type="file" id="file1" name="file1" />

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

  2016-07-28,评论中的一个错误:TypeError: $.ajaxFileUpload is not a function   我们用的不是同一个JS,你下了别的AJAXFileUpload去了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# jQuery  # ajaxFileUpload  # ajaxFileupload实现多文件上传功能  # jQuery插件ajaxFileUpload异步上传文件  # jQuery插件ajaxfileupload.js实现上传文件  # ThinkPHP结合AjaxFileUploader实现无刷新文件上传的方法  # ajaxFileUpload.js插件支持多文件上传的方法  # Thinkphp结合ajaxFileUpload实现ajax异步图片传输全套代码  # 上传  # 设置为  # 文件上传  # 自定义  # 返回值  # 都是  # 是一个  # 下载地址  # 请选择  # 上传图片  # 是否存在  # 错误提示  # 的是  # 在这里  # 去了  # 说了  # 要有  # 下了  # 这个问题  # 说到 


相关文章: 家具网站制作软件,家具厂怎么跑业务?  在线教育网站制作平台,山西立德教育官网?  建站上传速度慢?如何优化加速网站加载效率?  如何快速搭建高效服务器建站系统?  建站之星图片链接生成指南:自助建站与智能设计教程  如何在云服务器上快速搭建个人网站?  盘锦网站制作公司,盘锦大洼有多少5G网站?  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  济南企业网站制作公司,济南社保单位网上缴费步骤?  存储型VPS适合搭建中小型网站吗?  如何在Ubuntu系统下快速搭建WordPress个人网站?  教育培训网站制作流程,请问edu教育网站的域名怎么申请?  b2c电商网站制作流程,b2c水平综合的电商平台?  建站之星会员如何解锁更多建站功能?  南宁网站建设制作定制,南宁网站建设可以定制吗?  佛山企业网站制作公司有哪些,沟通100网上服务官网?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  XML的“混合内容”是什么 怎么用DTD或XSD定义  公司网站制作需要多少钱,找人做公司网站需要多少钱?  宝塔建站后网页无法访问如何解决?  网页设计与网站制作内容,怎样注册网站?  网站制作壁纸教程视频,电脑壁纸网站?  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?  网站设计制作企业有哪些,抖音官网主页怎么设置?  如何选择高性价比服务器搭建个人网站?  建站之星安装后如何自定义网站颜色与字体?  建站之星如何防范黑客攻击与数据泄露?  家庭服务器如何搭建个人网站?  如何配置IIS站点权限与局域网访问?  制作证书网站有哪些,全国城建培训中心证书查询官网?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  c# await 一个已经完成的Task会发生什么  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  如何选择最佳自助建站系统?快速指南解析优劣  商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?  Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解  建站主机是否等同于虚拟主机?  如何高效配置香港服务器实现快速建站?  如何快速搭建支持数据库操作的智能建站平台?  网站制作服务平台,有什么网站可以发布本地服务信息?  导航网站建站方案与优化指南:一站式高效搭建技巧解析  如何在IIS中新建站点并解决端口绑定冲突?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。