Я использую некоторый код из других хорошо зарекомендовавших себя публикаций SO для построения выпадающих списков с несколькими столбцами в таблицах данных, но я хотел бы добавить дополнительный HTML-код в структуру столбцов. Однако я незнаком и немного смущен тем, как jQuery строит HTML здесь. Функция, которая вызывается для построения HTML:
function cbDropdown(column) {
return $('<ul>', { 'class': 'cb-dropdown' })
.appendTo($('<div>', { 'class': 'LEVEL-TWO' })
.appendTo($('<div>', { 'class': 'LEVEL-ONE' })
.appendTo($('<div>', { 'class': 'cb-dropdown-wrap' })
.appendTo(column))));
}
Что я пытаюсь сделать, это вставить три строки HTML в класс LEVEL-ONE. По существу:
<div class="cb-dropdown-wrap>
<div class="LEVEL-ONE">
<div id="CountrySearchboxID">
<input class="searchInput"/>
</div>
</div>
<div class="LEVEL-TWO">
<ul class="LEVEL-TWO">
<li << lots of lis >> </li>
</ul>
</div>
</div>
Я пробовал разные варианты
$('.LEVEL-ONE').prepend('<div id="CountrySearchboxID"><input class="searchInput"/></div>');
Но когда я нажимаю на раскрывающийся контейнер в консоли, мои изменения, хотя они и не вызывают ошибок, не оказывают никакого влияния.
Может ли кто-нибудь помочь мне в этом? https://jsfiddle.net/7obqwupm/
<script type="text/javascript" src="https://code.jquery.com/jquery-1.12.4.js"></script>
<script type="text/javascript" src="https://cdn.datatables.net/1.10.16/js/jquery.dataTables.min.js"></script>
<script type="text/javascript" src="https://cdn.datatables.net/1.10.16/css/jquery.dataTables.min.css"></script>
$(document).ready(function() {
function cbDropdown(column) {
return $('<ul>', {
'class': 'cb-dropdown'
})
.appendTo($('<div>', {
'class': 'LEVEL-TWO'
})
.appendTo($('<div>', {
'class': 'LEVEL-ONE'
})
.appendTo($('<div>', {
'class': 'cb-dropdown-wrap'
})
.appendTo(column))));
}
$('#example').DataTable({
initComplete: function() {
this.api().columns().every(function() {
var column = this;
var ddmenu = cbDropdown($(column.header()))
.on('change', ':checkbox', function() {
var active;
var vals = $(':checked', ddmenu).map(function(index, element) {
active = true;
return $.fn.dataTable.util.escapeRegex($(element).val());
}).toArray().join('|');
column
.search(vals.length > 0 ? '^(' + vals + ')$' : '', true, false)
.draw();
// Highlight the current item if selected.
if (this.checked) {
$(this).closest('li').addClass('active');
} else {
$(this).closest('li').removeClass('active');
}
var active2 = ddmenu.parent().is('.active');
if (active && !active2) {
ddmenu.parent().addClass('active');
} else if (!active && active2) {
ddmenu.parent().removeClass('active');
}
});
column.data().unique().sort().each(function(d, j) {
var // wrapped
$label = $('<label>'),
$text = $('<span>', {
text: d
}),
$cb = $('<input>', {
type: 'checkbox',
value: d
});
$text.appendTo($label);
$cb.appendTo($label);
ddmenu.append($('<li>').append($label));
});
});
}
});
});
<table id="example" class="display" cellspacing="0" width="100%">
<thead>
<tr>
<th>Name</th>
<th>Position</th>
<th>Office</th>
<th>Age</th>
<th>Start date</th>
<th>Salary</th>
</tr>
</thead>
<tfoot>
<tr>
<th>Name</th>
<th>Position</th>
<th>Office</th>
<th>Age</th>
<th>Start date</th>
<th>Salary</th>
</tr>
</tfoot>
<tbody>
<tr>
<td>Tiger Nixon</td>
<td>System Architect</td>
<td>Edinburgh</td>
<td>61</td>
<td>2011/04/25</td>
<td>$320,800</td>
</tr>
<tr>
<td>Garrett Winters</td>
<td>Accountant</td>
<td>Tokyo</td>
<td>63</td>
<td>2011/07/25</td>
<td>$170,750</td>
</tr>
<tr>
<td>Ashton Cox</td>
<td>Junior Technical Author</td>
<td>San Francisco</td>
<td>66</td>
<td>2009/01/12</td>
<td>$86,000</td>
</tr>
<tr>
<td>Cedric Kelly</td>
<td>Senior Javascript Developer</td>
<td>Edinburgh</td>
<td>22</td>
<td>2012/03/29</td>
<td>$433,060</td>
</tr>
</tbody>
</table>