Заполнение таблицы из JSON с помощью jQuery - PullRequest
9 голосов
/ 06 октября 2011

Это эффективный способ наполнения таблицы данными JSON с использованием jQuery или есть лучший / менее затратный способ?Максимальное количество строк будет около 100. Я бы предпочел не использовать плагин.

JS:

$.ajax({
    url: 'public.json',
    dataType: 'json',
    success: function(data) {
        var row = '<tr class="header">';
        for (var i in data.headers) {
            row += '<th style=""><a href="#" class="sort"><span>' + data.headers[i] + '</span></a></th>';
        }
        row += '</tr>'
        $(row).appendTo('table.data');
        row = '';
        for (var i in data.rows) {
            row += '<tr id="' + i + '">';
            row += '<td>' + data.rows[i].date + '</td>';
            row += '<td>' + data.rows[i].company + '</td>';
            row += '<td>' + data.rows[i].location + '</td>';
            ...
            row += '</tr>';
        }
        $(row).appendTo('table.data');
    },
});

JSON:

{
    "headers": {
        "date": "Date",
        "company": "Company",
        "location": "Location",
        ...
    },
    "rows": [{
        "date": "09/18/2011",
        "company": "Company name",
        "location": "US",
        ...
    },
    ...
}

EDIT: По сути, я пытаюсь выяснить, является ли хорошая идея объединить все строки в строку, превратить ее в объект jQuery и затем добавить его в таблицу, предполагая, что это можно сделать несколько раз настраница для обновления данных.

1 Ответ

7 голосов
/ 06 октября 2011

Вместо синтаксиса for .. in и построения строк я бы использовал функцию jQuery.each()

Примерно так:

$.ajax({
    url: 'public.json',
    dataType: 'json',
    success: function(data) {
        var $tr =$('<tr>').addClass('header');
        $.each(data.headers, function(i,header){
            $tr.append($('<th>').append($('a').addClass('sort').attr('href','#').append($('span').text(header))));
        });
        $tr.appendTo('table.data');
        $.each(data.rows,function(i,row){
            $('<tr>').attr('id',i).
                append($('<td>').text(row.date)).
                append($('<td>').text(row.company)).
                append($('<td>').text(row.location)).appendTo('table.data');
        });
    }
});
...