jQuery无刷新上传之uploadify简单代码

先简单的侃两句:貌似已经有两个月的时间没有写过文章了,不过仍会像以前那样每天至少有一至两个小时是泡在园子里看各位大神的文章。前些天在研究“ajax无刷新上传”方面的一些插件,用SWFUpload实现了无刷新上传功能,不过个人觉得不是很完美。

昨天在网上找到了一个叫做uploadify的jquery上传插件,看到园子里有几篇文章也是介绍这个插件的,心想何不用这个试试。

不过园子里的这几篇文章用到的uploadify还是以前的旧版本uploadify-v2.1.0,我在官网上下载的是uploadify-v3.1版,其中的一些参数以及调用方法也不同了,还好官网有帮助文档。

(唯一感觉不爽的一点就是这个开发包是针对PHP的,官网并没有.NET版本,但至少原理都是一样的,简单的修改一下就可以了。还是那句话“不仅要知其然,还要知其所以然”,知其所以然了,一切都是浮云啊)

好了,废话不多说。先上个效果图,有图有真相:

一:从官网下载开发包添加到项目中,我对这个开发包做了一个精简,删去了那些PHP方面的文件

项目基本结构:

二:添加对css和js文件的引用:

注意jquery.js文件和uploadify.js文件调用顺序。

三:Default.aspx页面代码如下:

rush:js;">
<%--用来作为文件队列区域--%>

四:一般处理程序UploadHandler.ashx简单代码如下:

rush:csharp;"> public void ProcessRequest(HttpContext context) { context.Response.ContentType = "text/plain";
  //http://www.cnblogs.com/babycool/
  //接收<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>后的<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>
  HttpPostedFile file = context.Request.Files["Filedata"];
  //其他参数
  //string somekey = context.Request["someKey"];
  //string other = context.Request["someOtherKey"];
  //<a href="https://www.jb51.cc/tag/huoqu/" target="_blank" class="keywords">获取</a><a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>的保存路径
  string uploa<a href="https://www.jb51.cc/tag/dpath/" target="_blank" class="keywords">dpath</a> =
    HttpContext.Current.Server.MapPath("UploadImages" + "\\");
  //判断<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>的<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>是否为空
  if (file != null)
  {
    if (!Directory.Exists(uploa<a href="https://www.jb51.cc/tag/dpath/" target="_blank" class="keywords">dpath</a>))
    {
      Directory.CreateDirectory(uploa<a href="https://www.jb51.cc/tag/dpath/" target="_blank" class="keywords">dpath</a>);
    }
    //保存<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>
    file.SaveAs(uploa<a href="https://www.jb51.cc/tag/dpath/" target="_blank" class="keywords">dpath</a> + file.FileName);
    context.Response.Write("1");
  }
  else
  {
    context.Response.Write("0");
  } 

}

public bool IsReusable
{
  get
  {
    return false;
  }
}

五:用到的参数介绍:

通过查看jquery.uploadify-3.1.js中的认设置并参考官方文档可得知:

参数不重新指定则保持认:

swf:uploadify.swf 文件的相对路径

uploader:后台处理程序的相对路径

buttonText:按钮显示文字

上传文件的类型认为所有文件 'All Files' '*.*'

可以通过以下两参数指定,指定方法见步骤三中的代码

fileTypeDesc;fileTypeExts;

auto:为true表示选择文件自动上传;如果不想自动上传,需设定为false,并通过

rush:js;"> |

来指定是上传还是取消上传

multi:设置为true将允许多文件上传

method: 提交方式Post 或Get 认为Post;

queueSizeLimit:当允许多文件上传时,设置选择文件的个数,认值为999 ;

另外,取消上传图片的路径是设置在css文件中的;

其他更多设置可以参考官网的帮助文档。

六:将上传完成后显示的Complete显示中文

英文的Complete不能改成中文”,这可能是之前的版本不能进行修改。我通过查看源代码 jquery.uploadify-3.1.js找到了上传完成时显示内容

再参考官方的帮助文档,可以得知,在“

onUploadSuccess” 事件中可以设置上传完成后所执行的代码,则修改后的代码为:

rush:js;"> //选择文件自动上传 'auto': true,//设置为true将允许多文件上传 'multi': true,//上传成功后执行 'onUploadSuccess': function (file,data,response) { $('#' + file.id).find('.data').html(' 上传完毕');
    } 

还有一个需要注意的一点是:一般在设定了选择上传文件路径时比如只允许上传*.jpg;*.png;*.gif格式的图片文件,则除了指定fileTypeDesc;fileTypeExts;两个参数外,还要在服务器端即一般处理程序中再次对上传文件文件扩展名进行判断,以防一些用户跳过客户端验证上传恶意文件

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

相关文章

页面搜索关键词突出 // 页面搜索关键词突出 $(function () {...
jQuery实时显示日期、时间 html: &lt;span id=&quot...
jQuery 添加水印 &lt;script src=&quot;../../../.....
中文:Sys.WebForms.PageRequestManagerParserErrorExceptio...
1. 用Response.Write方法 代码如下: Response.Write(&q...
Jquery实现按钮点击遮罩加载,处理完后恢复 思路: 1.点击按...