• 风雨兼程,与党和人民同行 2019-05-23
  • 张鼎丞对人民军队建设作出的贡献 2019-05-23
  • 把党的领导贯穿军事科研工作各方面和全过程 2019-05-23
  • 在强国论坛和新浪微博上也就说了几句国产80后伟大的钢琴家,嚯!粉丝不干了,邮箱里塞满男性女性生殖器的骂声和愤慨声。其实,真没有诋毁的意思。比如,美国一家男性内衣 2019-05-22
  • 【理上网来·喜迎十九大】不忘初心、继续前进,勇于全面深化改革 2019-05-22
  • 这5件事预测你能否可以开心活过80岁 2019-05-22
  • 新疆14所高校大学生同台比赛 2019-05-21
  • 西南铁路端午假期发送400余万人次 两人不文明乘车或受失信惩戒 2019-05-21
  • 省委中心组成员到联系帮扶点开展专题调研 2019-05-21
  • 热刺中场埃里克森领衔 北欧童话能否续写逆袭新篇 2019-05-21
  • 在深入推动长江经济带发展座谈会上的讲话 2019-05-20
  • 北京副中心核心区建成世界超一流智能配电网 2019-05-20
  • 江苏:五峰山跨江线路升高改造工程启动(组图) 2019-05-20
  • 无视婚变传闻 王浩信晒与朋友新旧对比照秀友情 2019-05-19
  • 专访香港演员陈钰芸:女版李小龙 用武术演绎精彩人生 2019-05-19
  • Jquery中文网 码报 www.okkrb.tw
    Jquery中文网 >  jQuery  >  jquery 教程  >  正文 jQuery+FormData+文件上传+上传进度

    119期码报:jQuery+FormData+文件上传+上传进度

    发布时间:2016-09-18   编辑:码报 www.okkrb.tw
    jquery中文网为您提供jQuery+FormData+文件上传+上传进度等资源,欢迎您收藏本站,我们将为您提供最新的jQuery+FormData+文件上传+上传进度资源

    码报 www.okkrb.tw 总结我做HTML5文件上传插件遇到的技术问题

    先贴上源码:fileupload-html5.js(PS:公司使用seajs框架)


    问题列表

    1. jquery.ajax没有监听上传进度的onprogress事件。

    2. XMLHttpRequest(XHR)跨域


    问题解答

    1. jQuery没有给出onprogress事件的接口,必须从其他接口中找到原生XHR对象。

    jQuery.ajax()返回的是jqXHR对象。jqXHR模仿XHR(原生),但没有模仿实现XHR的所有方法和属性(如:.upload),即使jqXHR增加了一个特有方法(如:.promise())。所以jqXHR并不是XHR的超集。

    //下面是截取jQ内部的源码,$.ajax();返回的就是这个jqXHR(伪造XMLHttpRequest)
    // Fake xhr
        jqXHR = {
    
            readyState: 0,
    

    XHRupload属性指向XMLHttpRequestUpload(IE10是XMLHttpRequestEventTarget),该对象的onprogress事件可以监听上传进度。既然jQ没有给出这个功能的api,但jQ某些数据上传方式是使用XHR的,所以我们可以从其它api中找到XHR。在XHR发送数据之前绑定onprogress事件可以实现上传进度功能。

    我从options参数配置中找到两个与XHR有关的属性:

    - xhr:回调创建XMLHttpRequest对象。

    xhr()返回值是XHR,提供给jQ使用,即发送数据就是用这个XHR。我们可以通过xhr创建一个回调函数覆盖它,同样返回XHR,但在此绑定onprogress事件。

    //jQ源码
    // Get a new xhr
    var handle, i,
        xhr = s.xhr();//[回调]在这里,下面是open方法
    
    // Open the socket
    // Passing null username, generates a login popup on Opera (#2865)
    if ( s.username ) {
        xhr.open( s.type, s.url, s.async, s.username, s.password );
    } else {
        xhr.open( s.type, s.url, s.async );
    }
    

    所以我们应该这样做:

    $.ajax({
        //.....
        xhr: function() {
            var xhr = $.ajaxSettings.xhr();
            //绑定上传进度的回调函数
            xhr.upload.addEventListener('progress', progress, false);
            return xhr;//一定要返回,不然jQ没有XHR对象用了
        }
    });
    
    - xhrFields:一对“文件名-文件值”组成的映射,用于设定原生的 XHR对象。

    xhrFields属性指向jQ内部创建的XHR,我们可以根据xhrFields获得XMLHttpRequest。由于xhrFields的值只能是json对象,所以不能以下面方式获取。

    //错误例子
    $.ajax({
        //......
        xhrFields: {
            upload.onprogress: function() {
                //语法错误
            }
        }
    });
    

    我们可以借助XHRonsendstart事件,如下:

    $.ajax({
        //......
        xhrFields: {
            onsendstart: function() {
                //this是指向XHR
                this.upload.addEventListener('progress', progress, false);
            }
        }
    });
    

    2. XMLHttpRequestⅡ(XHR)支持跨域,但需要后台允许。

    //后台需发送头部验证
    if($_REQUEST['cros']) {
        header("Access-Control-Allow-Origin:请求的域名");
    }
    

    根据后台给的接口,我需要增加一个参数cros。但我将这个参数与文件同事提交,却提示跨域限制。最后将这个参数放在url才行。
    原来XHR跨域是有两次请求的,第一次是验证请求,浏览器根据请求目的地址自动发出options请求。若通过,才能发出自定义的post请求。所以将参数放在post请求里,第一次请求没有cros参数,即不能通过。

    您可能感兴趣的文章:
    文件上传插件 jQuery File Upload
    Web文件上传???Plupload
    Web文件上传???Plupload
    jQuery File Upload
    jQuery File Upload
    jQuery文件上传插件 jcUpload
    jQuery异步上传插件
    Jquery上传插件 uploadify v3.1使用说明
    jQuery异步上传插件
    jquery ajax提交整个表单元素的快捷办法

    [关闭]
  • 风雨兼程,与党和人民同行 2019-05-23
  • 张鼎丞对人民军队建设作出的贡献 2019-05-23
  • 把党的领导贯穿军事科研工作各方面和全过程 2019-05-23
  • 在强国论坛和新浪微博上也就说了几句国产80后伟大的钢琴家,嚯!粉丝不干了,邮箱里塞满男性女性生殖器的骂声和愤慨声。其实,真没有诋毁的意思。比如,美国一家男性内衣 2019-05-22
  • 【理上网来·喜迎十九大】不忘初心、继续前进,勇于全面深化改革 2019-05-22
  • 这5件事预测你能否可以开心活过80岁 2019-05-22
  • 新疆14所高校大学生同台比赛 2019-05-21
  • 西南铁路端午假期发送400余万人次 两人不文明乘车或受失信惩戒 2019-05-21
  • 省委中心组成员到联系帮扶点开展专题调研 2019-05-21
  • 热刺中场埃里克森领衔 北欧童话能否续写逆袭新篇 2019-05-21
  • 在深入推动长江经济带发展座谈会上的讲话 2019-05-20
  • 北京副中心核心区建成世界超一流智能配电网 2019-05-20
  • 江苏:五峰山跨江线路升高改造工程启动(组图) 2019-05-20
  • 无视婚变传闻 王浩信晒与朋友新旧对比照秀友情 2019-05-19
  • 专访香港演员陈钰芸:女版李小龙 用武术演绎精彩人生 2019-05-19