Как вставить HTML в выпадающий список столбцов с данными - PullRequest
0 голосов
/ 01 апреля 2019

Я использую некоторый код из других хорошо зарекомендовавших себя публикаций 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>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...