jqXHR.abort不是一个函数

时间:2014-03-23 14:23:01

标签: jquery jquery-file-upload

我正在尝试为jquery文件上传取消按钮(http://blueimp.github.io/jQuery-File-Upload/)。

我的代码:

var jqXHR = $('#fileupload').fileupload({
url: 'server/index.php',
dataType: 'json',
dropZone: $('#dropzone'),
})

$('button.cancel').click(function (e) {
    jqXHR.abort();
    alert("cancel");
});

当我点击取消按钮时,取消按钮不起作用,我得到" jqXHR.abort不是一个函数"错误。

取消按钮取消文件上传工作需要做什么?

2 个答案:

答案 0 :(得分:9)

根据文档,应该这样做。

var jqXHR = null;
$('#fileupload').fileupload({
    url: 'server/index.php',
    dataType: 'json',
    dropZone: $('#dropzone'),
    add: function (e, data) {
        jqXHR = data.submit();
    }
});

现在你可以像这样访问jqXHR对象了

$('button.cancel').click(function (e) {
    jqXHR.abort();
});

对于多次中止,方法将是

$('#fileupload').fileupload({
    add: function(e, data) {
         $('.progress_bar_wrapper').append($('.progress_context:first').clone());
        data.context = $('.progress_context:last');
        data.content.find('.abort').click(abortUpload );
        var xhr = data.submit();
        data.context.data('data',{jqXHR: xhr}); // so much data...
    }
)};

function abortUpload (e) {
     e.preventDefault();
     var template = $(e.currentTarget).closest('.template-upload'),
     data = template.data('data') || {}; // data, data , data (queue Monty Python skit)
      if (!data.jqXHR) {
        data.errorThrown = 'abort';
        this._trigger('fail', e, data);
      } else {
        data.jqXHR.abort();
      }
}

参考:https://github.com/blueimp/jQuery-File-Upload/issues/290

答案 1 :(得分:2)

正如document API所述,您应该使用send方法取回jqXHR。这对你有用

var jqXHR = $('#fileupload').fileupload('send', {
    url: 'server/index.php',
    dataType: 'json',
    dropZone: $('#dropzone'),
});

$('button.cancel').click(function (e) {
    jqXHR.abort();
    alert("cancel");
});