jQuery技术

jQuery无刷新上传学习心得

字号+ 作者:H5之家 来源:H5之家 2017-07-27 09:01 我要评论( )

jQuery无刷新上传学习心得,记得刚离开大学,进入目前这家公司不到一个月时,有一位前辈给我们当时的新人讲了下JS无刷新上传的相关知识。在此之前,一直都是在使

正文

记得刚离开大学,进入目前这家公司不到一个月时,有一位前辈给我们当时的新人讲了下JS无刷新上传的相关知识。

在此之前,一直都是在使用C#提供的服务器上传控件FileUpload,但是每次使用时,都会刷新一次页面,给人的感觉不是太好。但是那是,并不是太在意这个细节,而且JS知识非常匮乏,所以并没有去找解决的办法。

当时,这位前辈提到的一种方法是:

准备一个主页面(用户界面)和一个上传页(放在主页面隐藏的iframe中,作为真正意义的上传页),当点击主页面的上传按钮时,实际上是调用了上传页的上传控件,从而来实现上传。而这个套操作并不是没有刷新,只是刷新是在上传页完成的,用户感觉不到罢了。

这个原理其实就是,一个iframe+一个form+一个上传控件,上传实际上是在提交iframe下的form,上面这个方法,需要用到的iframe、form和上传控件都是事先写好,存在一个实际的页面中。

通过之前在网上所了解的,我们可以利用JS或jQuery动态的创建iframe、form和上传控件。

步骤如下:

1、创建一个iframe,添加到文档中

1 var iframe = $("<iframe src='javascript:false;'></iframe>").appendTo(document.body)[0];
2 $(iframe).attr("onload", "IframeLoad('" + id + "', '" + this._imgpanel + "')");

2、创建一个form,添加到文档中,并将其target属性指向上面创建的iframe

1 var form = $("<form action='" + this._url + "' method='POST' enctype='multipart/form-data'></form>").appendTo(document.body)[0]; 2 form.target = iframe.name;

3、创建一个上传控件,添加到上面这个form中

1 this._control = $("<input type='file' />"); 2 this._control.appendTo(form); 3 this._control.attr("onchange", "fileChangeHandler(this,'" + form.id + "','" + id + "')");

4、实现这个上传控件的onchange事件,已完成上传

1 var fileChangeHandler = function (obj, formid, fupid) { $("#" + formid).submit(); 4 };

5、提交后需要后台接收并完成上传。由于本人主要是C#开发,这里就给个C#的上传代码(擅长其他编程语言的,可以用自己方式)。首先建一个一般处理程序handler.ashx,然后获取提交的文件,最后实现上传并返回重要信息。

1      Request = context.Request; HttpFileCollection files = Request.Files;string newfilepath = ""; 5 if (files.Count > 0) 6 { 7 string path = Server.MapPath("upfiles/"); 8 if (!Directory.Exists(path)) 9 { 10 Directory.CreateDirectory(path); 11 } 12 HttpPostedFile file = files[0]; 13 string newfilename = DateTime.Now.ToString("yyyyMMddHHmmdd") + Path.GetExtension(file.FileName); 14 file.SaveAs(path + newfilename); 15 newfilepath = "upfiles/" + newfilename; Response.Write(newfilepath); 19 Response.End();

6、前台接收返回消息的方法如下

1 var msg = $("#" + iframeid)[0].contentDocument.body.innerHTML;

注:iframeid为创建的iframe的id。后台返回的消息会显示到这个iframe的body里面,这里就只需要抓取到这个值就行了。

具体实现我放在一个Demo里面,有兴趣的园友可以下载下来阅示,如有不足之处,还望能批评斧正。

感谢!

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • jQuery教程视频_text_html

    jQuery教程视频_text_html

    2017-07-27 11:00

  • js学习小结-案例之鼠标跟随jquery版

    js学习小结-案例之鼠标跟随jquery版

    2017-07-27 09:00

  • jquery中关于属性的学习

    jquery中关于属性的学习

    2017-07-27 08:03

  • ajax操作之使用JSONP加载远程数据

    ajax操作之使用JSONP加载远程数据

    2017-07-26 11:03

网友点评