How to merge data from many Ajax requests

How to merge data from many Ajax requests

MeethMeeth Posts: 3Questions: 1Answers: 0
edited June 2022 in Free community support

I would like to know how to combine the json data from multiple API calls into one object. Essentially, this is what I would like to do:

$('.table').DataTable({
    ajax: {
        url: 'url-1.com' + 'url-2.com',
        dataSrc: ''
    },
    columns:[
        { 'data' : 'firstName-from-url-1' },
        { 'data' : 'surname-from-url-1' },
        { 'data' : 'balance-from-url-2' },
        { 'data' : 'comment-from-url-2' }
    ],
});

This question has accepted answers - jump to:

Answers

  • kthorngrenkthorngren Posts: 21,558Questions: 26Answers: 4,994
    Answer ✓

    url: 'url-1.com' + 'url-2.com',

    This won't work as you can only define one URL. You could use the ajax option as a function and inside the function use jQuery ajax to fetch the multiple API's. Then use a loop to combine the responses into one object to return to Datatables. This example uses ajax as a function.

    Or you can use the same technique with jQuery ajax outside of Datatables. You can either initialize an empty Datatable, ie no ajax option, before calling the API's or you can init Datatables after all the data as been combined with the data option.

    The tricky part, since ajax is asynchronous, is using tow ajax requests to fetch the data and combining it. This CO thread has a couple opions.

    Kevin

  • MeethMeeth Posts: 3Questions: 1Answers: 0
    edited June 2022

    I think I will use a loop to combine the results. I'm trying to figure out how the callback function works from anonymous function:

    $(".table").DataTable({
                        ajax: function(data, callback, settings){
                            $.ajax({
                                url: "https://localhost:" + portNumber + "/clients",
                                dataType: "json",
                                success: function(response){
                                    callback(response);
                                }
                            });
                        },
                        columns:[
                            { data : 'firstName' },
                            { data : 'surname' }
                        ],
                    });
    

    I get the following error: Uncaught TypeError: Cannot read properties of undefined (reading 'length'). I think I can fix this by passing dataSrc:'' into the callback function. But how can I set the dataSrc property from the callback function?

  • kthorngrenkthorngren Posts: 21,558Questions: 26Answers: 4,994
    Answer ✓

    Uncaught TypeError: Cannot read properties of undefined (reading 'length')

    Without seeing what you have its hard to say. One of the typical issues with this error is the number of columns in the HTML thead don't match the number defined in columns. Do you have two th defined in the thead?

    I think I can fix this by passing dataSrc:''

    I would do something like the example I linked to and place the data in the data object`, maybe like this:

                                success: function(response){
                                    callback( {data: response} );
                                }
    

    Kevin

  • MeethMeeth Posts: 3Questions: 1Answers: 0

    Excellent! That worked. I think I will be able to take it from here. Thank you.

This discussion has been closed.