Как динамически добавлять HTML-элемент, используя JavaScript и Firefox Add-on SDK

Я разрабатываю простое дополнение к Firefox SDK, которое позволяет пользователю просматривать сохраненные данные. Я хотел бы показать элементы в панели с таблицей. Таблица создается динамически с данными, поступающими из базы данных. Во-первых, в коде JavaScript я создаю элементы с их свойствами, затем я создаю таблицу со свойствами в виде строки и добавляю элементы со значением каждого свойства.

У меня есть некоторые проблемы: таблица содержит только имя элемента в качестве первой строки и имя свойства в качестве первого столбца без значения в ячейках. Кажется, что код выполняется не по порядку, но кажется, что более быстрые функции выполняются первыми.

Это код:

       self.on('message', function() {
        var container = $('#container');
        container.empty();
        items = [];
        self.port.emit('getItem');
    });

    self.port.on('items', function(response) {
        var ok = 0;
        var items = [];
        var table = $('#tableContainer #table').clone();
        var container = $('#container');

        table.append("<tr id=first><th>    </th></tr>");
        var json = eval('('+ response + ')');
        for (var i = 0, len = json.length; i < len; ++i) {
            var item = {
                id: json[i],
                properties: []
            };
            items.push(item);
        }
        items.forEach ( function(item) {    
            table.find('#first').append("<th id="+item.id+">"+item.id+"</th>");

            self.port.emit('detailsItem', item.id);
            self.port.on('details'+item.id,  function(response) {
                var details = eval('('+ response + ')');
                var description = [];
                ndet = details.length;
                var len = details.length;
                for (var i = 0; i < len;) {
                    var detail = {
                        dimension : details[i].dimension,
                        value : details[i].value
                    }
                                    description.push(detail);
                    ++i;
                }
                item.properties = description;  
            });
            });
        self.port.emit('getDimension'); 
            self.port.on('dimension', function(response) {
                var dimensions = eval('('+ response + ')');
                for(var cont = 0, l = dimensions.length; cont < l; ++cont) {
                    table.append("<tr id=dimension"+cont+"><td>"+dimensions[cont]+"</td></tr>");    

                    items.forEach( function(item) {
                        var prop = [];
                        prop = item.properties;
                        var lun = prop.length;
                        for( var p =0;p < lun;) {
                            if(item.properties[p].dimension == dimensions[cont]) {                              table.find('#dimension'+cont).append("<td>"+item.properties[p].value+"</td>");
                            }
                            else {
                                table.find('#dimension'+cont).append("<td> --- </td>");
                            }
                            ++p;                        }

                    });

                };
        });

            container.append(table);

        });

0 ответов

Другие вопросы по тегам