The server returns json, which includes 2 segments of data, and the 2 segments are loaded in 2 table
The server returns json, which includes 2 segments of data, and the 2 segments are loaded in 2 table
 feng xia            
            
                Posts: 9Questions: 3Answers: 0
feng xia            
            
                Posts: 9Questions: 3Answers: 0            
            <script >
    $(document).ready(function() {
    $.ajax({
            url:'/queryseller/queryseller',
            type: 'POST',
            data:{
                date:currtime,
                csrfmiddlewaretoken:$('[name=csrfmiddlewaretoken]').val(),
            },
            success:function(res){
                tableformat(res.data)
                brandseller(res.data2);
            },
        }); …………
tableformat and brandseller code
function tableformat(data){
        $('#ple').DataTable({  
             data: data,
            "dom": '<"top"flp>t<"bottom"i><"clear">',
            "columns":[
                { "width": "10%" },
                { "width": "15%" },
                null,
                { "width": "10%" },
                { "searchable": false },
            ],
……
Here are perfect, but I want to load the Child rows in the page, here it does not work, I test is caused by the order of javascript loading, JSON data has not been loaded on the implementation of var table = $ ('#ple').DataTable ();, resulting in the first table (ple) failed to load, the second table is normal, the If I do not execute var table = $('#ple').DataTable();. The Child rows can't load
Child rows code
                var table = $('#ple').DataTable();
                function format ( d ) {
                        // `d` is the original data object for the row
                        var order_table = "<div class= \"row\"><div class=\"col-10\">"+d+"</div></div>";
                        // order();
                        return order_table
                    }
                $('#ple tbody').on('click', 'td', function () {
                            var tr = $(this).closest('tr');
                            var row = table.row( tr );
                            alert('ok'+row.data()[0])
                            $.ajax({
                                url:'/queryseller/queryproducts',
                                type: 'POST',
                                data:{
                                    date:row.data()[0],
                                    csrfmiddlewaretoken:$('[name=csrfmiddlewaretoken]').val(),
                                },
                                success:function(res){
                                    if ( row.child.isShown() ) {
                                        row.child.hide();
                                        tr.removeClass('shown');
                                    }
                                    else {
                                        row.child( format(res) ).show();
                                        tr.addClass('shown');
                                    }
                                }
                            });
                        });
                    })
Is there any way to load the JSON data returned by the server in 2 tables that can be used Child rows
Answers
If I understand the problem correctly:
You can move line 1 (
var table = $('#ple').DataTable();) of the child code into the event handler, insert between line8 and 9.or
You can make the variable
tablea global variable then on line 1 just havetable = $('#ple').DataTable();.Kevin
I've tried all your methods, and I've tried writing Child rows as a function, but it doesn't work either.
I found a solution, first generate new DataTable, then AJAX and then