jQuery插件ajaxFileUpload的用法(ASP.NET)

2014-07-23 20:34:40|?次阅读|上传:wustguangh【已有?条评论】发表评论

关键词:JavaScript, JQuery, 界面设计, Web, ASP.NET|来源:唯设编程网

ASP.net使用JQuery类库ajaxFileUpload实现文件上传介绍了ASP.net使用ajaxFileUpload上传文件的方法,本文继续对这部分内容进行介绍,以加深对这部分内容的理解。

1.ajaxFileUpload插件概述

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

语法:$.ajaxFileUpload([options])

  options参数说明:

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

错误提示:

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

2.ajaxFileUpload插件的使用实例

第一步:先引入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>

该HTML代码包含一个file控件和一个button控件,此外还有一个图片。

第三步: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>

这段代码直接嵌入在html文件中,使用<script></script>将其包含,通过JQuery绑定了按钮的click事件,当用户点击按钮时,调用ajaxFileUpload函数。ajaxFileUpload函数使用了ajaxFileUpload插件实现文件上传,关于ajaxFileUpload插件已经在第一部分进行了介绍。success是上传成功后执行的函数,上传成功后,将界面中的图片路径改为上传成功的图片,用户可以浏览其效果,如果上传失败,则调用aler弹出消息提示对话框。

第四步:后台页面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();
     }
}

后台代码非常简单,直接在Page_Load中实现,核心类就是HttpFileCollection,该类的SaveAs将用户上传的文件保存到服务器,最终实现上传功能。res是手动构造的一个json数据,用来返回给客户端进行状态提示。

本文转载自:http://www.cnblogs.com/kissdodog/archive/2012/12/15/2819025.html

发表评论0条 】
网友评论(共?条评论)..
jQuery插件ajaxFileUpload的用法(ASP.NET)