DataTables: фильтр по пользовательскому атрибуту данных - PullRequest
0 голосов
/ 25 февраля 2019

Я хочу отфильтровать таблицу данных, выбрав фильтр на входе выбора.

<select class="form-control filter-table" data-column="language">
  <option selected>Alle Sprachen</option>
  <option value="GER">Deutsch</option>
  <option value="ENG">Englisch</option>
</select>

Вот как устроена моя таблица:

<tr>
  <td>Hello</td>  <td data-language="ENG">Englisch</td>
</tr>
<tr>
  <td>Hello</td>  <td data-language="GER">German</td>
</tr>

Вот мой обработчик событий:

$('.filter-table').change(function (e) {
    var column = $(this).data('column');
    var filter = $(this).val();
});

Я уже довольно долго искал, но не нашел ответа

Ответы [ 2 ]

0 голосов
/ 26 февраля 2019

Если вы ищете универсальное решение jQuery, вы можете проверить это:

	//populate options
	$('#lang').append([...$('#mytable tr td:nth-of-type(2)')].sort().reduce((options, option) => options+=`<option value="${$(option).text()}">${$(option).text()}</option>`,'<option value="All" selected>All</option>'));
	
  //grab table data
	const tableDataObj = {};
	tableDataObj.data = [...$('#mytable tbody tr')].map(row => {
		const rowObj = {};
		[...$(row).children('td')].forEach((cell, index) => rowObj[$(`#mytable thead th:eq(${index})`).text()] = $(cell).text());
		return rowObj;
	});
	tableDataObj.header = [];
	tableDataObj.data.map(row => Object.keys(row)).flat().forEach(entry => {
		if(tableDataObj.header.indexOf(entry) == -1) tableDataObj.header.push(entry);
	});
	
  //draw table upon selection
	$('#lang').on('change', function() {
		const filteredData = JSON.parse(JSON.stringify(tableDataObj));
		filteredData.data = filteredData.data.filter(entry => entry.Language == $(this).val() || $(this).val() == 'All');
		$('#mytable').html('<table></table>');
		$('#mytable').append('<thead><tr>'+filteredData.header.reduce((thead, th) => thead+=`<th>${th}</th>`,''));
		$('#mytable').append(`<tbody>${Object.values(filteredData.data).reduce((rows, row) => rows+='<tr>'+Object.values(row).reduce((tds, td) => tds += '<td>'+td+'</td>','')+'</tr>','')}</tbody>`);
	});
<!doctype html>
<html>
	<head>
		<script type="application/javascript" src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
		<script type="application/javascript" src="test.js"></script>
		<link rel="stylesheet" type="text/css" href="test.css">
		</head>
		<body>
			<select id="lang"></select>
			<table id="mytable">
				<thead>
					<tr>
						<th>Greeting</th><th>Language</th>
					</tr>
				</thead>
				<tbody>
					<tr>
						<td>Hello</td><td>English</td>
					</tr>
					<tr>
						<td>Hallo</td><td>Deutsch</td>
					</tr>
					<tr>
						<td>Selam</td><td>Turkce</td>
					</tr>
					<tr>
						<td>Salut</td><td>Francais</td>
					</tr>
					<tr>
						<td>Ciao</td><td>Italiano</td>
					</tr>
				</tbody>
			</table>
		</body>
	</html>

Это не так уж и элегантно и масштабируемо, но дает общую идею.

Если вы запрашивали решение DataTables, я могу порекомендовать это плагин.С ним вам не нужно использовать дополнительные выпадающие списки - он аккуратный и простой, хотя в раннем выпуске он полностью соответствует вашим требованиям.При таком подходе вы можете получить несколько фильтров выбора в дополнение к базовой сортировке DataTables, разбивке на страницы / прокрутке.Вот это DEMO .

0 голосов
/ 25 февраля 2019

Я предполагаю, что вы используете плагин DataTables Jquery.

<select id="dropdown1" class="form-control filter-table" data-column="language">
<option selected>Alle Sprachen</option>
<option value="GER">Deutsch</option>
<option value="ENG">Englisch</option>
</select>
<table id="example" class="display" cellspacing="0" width="100%">
<thead>
        <tr>
            <th>Greeting</th>
            <th>Language</th>
        </tr>
    </thead>
<tr>
<td>Hello</td>  <td data-language="ENG">Englisch</td>
</tr>
<tr>
<td>Hello</td>  <td data-language="GER">German</td>
</tr>
</table>

Javascript:

$(document).ready(function() {
   var table =  $('#example').DataTable();

 $('#dropdown1').on('change', function () {
     if(this.value=="Alle Sprachen")
      {
      table.columns(1).search('').draw();
      }
      else
      {
      table.columns(1).search( this.value ).draw();
      }                   
   } );

});

Рабочая скрипка: https://jsfiddle.net/an5kbx0z/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...