Jump to content
  • 0

Пересортировать ячейки таблицы


botyaslonim
 Share

Question

Привет всем!

Есть таблица вот примерно такого вида:

0_a289a_d41d3c38_orig.jpg

Нужно привести её к такому виду:

0_a289b_480d13ca_orig.jpg

То есть место ячейки в строке должно быть одинаковым, если одинаковое содержание, либо оставить ячейку пустой.

Что-от у меня никак не выходит. Получаются какие-то переборы двойной вложенности, но всё некрасиво и громоздко. Может, есть более изящное решение?

Link to comment
Share on other sites

14 answers to this question

Recommended Posts

  • 0

В смысле? Из рисунка не очень ясно, что нужно сделать? :huh:

Лыжи под лыжами, санки под санками, и т.д. Смысл - ячейкам со сходной информацией назначить одно и то же расположение относительно начала строки таблицы.

Link to comment
Share on other sites

  • 0

Думаю, это не имеет значения, а то мы зароемся в детали. Исходная таблица берётся из Joomla K2, изначально всё вразнобой. Пузырьковой сортировкой вывел вверх самую длинную строку, дорисовал более коротким пустые ячейки (до нужного числа ячеек, равного числу ячеек самой длинной). Цель - построить таблицу шириной в самый длинную строку, с логичными столбцами.

Но мне интересно решить именно эту задачу, когда уже нужно сделать из рисунка 1 рисунок 2. В дальнейшем, думаю, пригодится.

Edited by botyaslonim
Link to comment
Share on other sites

  • 0

Тогда я бы сделал ассоциативный массив вхождений каждой категории, типа

var entries = {
шапки: {
1: "шапки", 3: "шапки" // номер строки - содержимое соотв. ячейки
},
лыжи: {
1: "лыжи", 2: "лыжи"
},
...
}

а потом обходил бы циклом а-ля


for (var i=1; i<=rows.length; i++) {
html += '<tr>';
for (var category in entries) {
if (entries[category][i]) {
html += '<td>' + entries[category][i] + '</td>';
}
else {
html += '<td></td>';
}
}
html += '</tr>';
}
target.innerHTML = '<table>' + html + '</table>';

(набросал на скорую руку, не проверял и тем более не оптимизировал, чисто для иллюстрации идеи)

Link to comment
Share on other sites

  • 0
То есть место ячейки в строке должно быть одинаковым, если одинаковое содержание, либо оставить ячейку пустой.

в столбце

какой вопрос, такой ответ

var table = document.getElementsByTagName( 'table' )[ 0 ];
var pattern = Array.prototype.map.call( table.rows[ 0 ].cells, function( cell, index ) {
return cell.innerHTML;
});

Array.prototype.slice.call( table.rows, 1 ).forEach( function( row ) {

var data = Array.prototype.map.call( row.cells, function( cell, index ) {
return cell.innerHTML;
});
var newData = pattern.map( function( item ) {
return ~data.indexOf( item ) ? item : '';
});

Array.prototype.forEach.call( row.cells, function( cell, index ) {
cell.innerHTML = newData[ index ];
});

});

UPD: чет голова на ночь совсем не варит. Можно проще

var table = document.getElementsByTagName( 'table' )[ 0 ];
var pattern = Array.prototype.map.call( table.rows[ 0 ].cells, function( cell, index ) {
return cell.innerHTML;
});

Array.prototype.slice.call( table.rows, 1 ).forEach( function( row ) {

var data = Array.prototype.map.call( row.cells, function( cell, index ) {
return cell.innerHTML;
});

pattern.forEach( function( item, index ) {
row.cells[ index ].innerHTML = ~data.indexOf( item ) ? pattern[ index ] : '';
});

});

Edited by nerv
Link to comment
Share on other sites

  • 0

nerv, спасибо, работает!

Вопрос следующий. Можно ли сделать пересортировку этим же методом, но для таблицы такого вида:

0_a2c51_f28aa570_orig.jpg

0_a2c52_ce87857_orig.jpg

Некоторые важные детали вопроса выслал в личку

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

 Share

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue. See more about our Guidelines and Privacy Policy