$('td').filter(function() {
return $(this).next().text().trim() === '';
}).each(function() {
var $original = $(this);
if (!$original.hasClass('remove')) {
var counter = 1,
$item = $original;
do {
if ($item.next().text().trim() === '') {
counter++;
$item = $item.next().addClass('remove');
}
} while ($item.next().length && $item.next().text().trim() === '');
$original.attr('colspan', counter);
}
});
$('.remove').remove();
$('td').filter(function() {
$prev = $(this).prev();
return $prev.length && $prev.text().trim() === '';
}).each(function() {
var $original = $(this),
$prev = $original.prev();
var colspan = getColspan($original) + getColspan($prev);
$original.attr('colspan', colspan);
$prev.remove();
});
function getColspan($elem) {
var attr = $elem.attr('colspan');
if (typeof attr !== typeof undefined && attr !== false) {
return parseInt(attr);
}
return 1;
}
td {
vertical-align: top;
border: 1px solid black;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="curriculum">
<table class="table table-responsive">
<tbody>
<tr>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
</tr>
<tr>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td></td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td></td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td></td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td></td>
</tr>
<tr>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td></td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td>Lorem ipsum dolor sit amet, consectetur adipisicing elit</td>
<td></td>
</tr>
</tbody>
</table>
</div>