Javascript, jQuery multiple AJAX requests at same time

前端 未结 1 1953
[愿得一人]
[愿得一人] 2021-01-21 10:51
function makeCall(file, handlerFile, sendMethod, formData) {
    //console.log(instance.files);

    $.ajax({
        url: handlerFile,
        type: sendMethod,
                


        
相关标签:
1条回答
  • 2021-01-21 11:24

    It's easy to make it with jQuery.when();

    Ajax calls can be any number. So you need to use it with apply(); and create array of ajax calls. Now code looks like this:

    function makeCall(file, formData) {
        return $.ajax({ // It's necessary to return ajax call 
           url: 'handler.php',
           type: 'POST',
           xhr: function() { // Creating custom XHR to register progress event(If you know better solution - please post ir)
               var xhr = $.ajaxSettings.xhr();
    
               if (xhr.upload) { // Check if upload property exists
                   xhr.upload.addEventListener('progress', progressHandlingFunction.bind(file)); // Registering progress event
               }
    
               return xhr;
           },
           // Events handlers
           beforeSend: beforeSendHandler.bind(file),
           success: completeHandler,
           data: formData,
           dataType: 'json',
           cache: true,
           contentType: false,
           proccessData: false
        });
    }
    
    $('.afu-input').on('change', function() {
        var files = this.files;
        var calls = [];
    
        $.each(files, function(i, file) {
            uid = generateUniqueId();
            file.id = uid;
    
            var formData = new formData();
    
            formData.append(0, file); // Just easier to set index to 0 cause for every file returning new obejct, so is no point to set more indexes
    
            calls.push(makeCall(file, formData)); // And finally pushing calls to array
        });
    
        // Using jQuery.when
        // Cause I don't know how many calls will be I'm using "apply" so I can add array instead of one by one calls
        $.when.apply($, calls); // Exactly I don't know why need "$"
    }
    
    function beforeSendHandler() {
        console.log(this);
    }
    
    function completeHandler(data) {
        console.log(data);
    }
    
    function progressHandlingFunction(e) {
        console.log(e);
        console.log(this);
    }
    
    0 讨论(0)
提交回复
热议问题