table内をテキスト検索して該当キーワードを持つ列を表示する

Ads

Result

table内のすべてのテキストから検索し、該当箇所のある列を表示する、みたいなやつ
ある程度の量を持つデータテーブルだけど超大量でもないから、重いスクリプトは使いたくない、みたいな中途半端な状況の時は少ないコードで済ませたいところですね

vanillaなコードで動作します

JavaScript

(function(document) {
	'use strict';
	var LightTableFilter = (function(Arr) {
		var _input;
		function _onInputEvent(e) {
			_input = e.target;
			var tables = document.getElementsByClassName(_input.getAttribute('data-table'));
			Arr.forEach.call(tables, function(table) {
				Arr.forEach.call(table.tBodies, function(tbody) {
					Arr.forEach.call(tbody.rows, _filter);
				});
			});
		}

		function _filter(row) {
			var text = row.textContent.toLowerCase(), val = _input.value.toLowerCase();
			row.style.display = text.indexOf(val) === -1 ? 'none' : 'table-row';
		}

		return {
			init: function() {
				var inputs = document.getElementsByClassName('light-table-filter');
				Arr.forEach.call(inputs, function(input) {
					input.oninput = _onInputEvent;
				});
			}
		};
	})(Array.prototype);

	document.addEventListener('readystatechange', function() {
		if (document.readyState === 'complete') {
			LightTableFilter.init();
		}
	});

})(document);
Ads

html

<section class="container">
	<input type="search" class="light-table-filter" data-table="order-table" placeholder="検索" />
	<table class="order-table">
		<thead>
			<tr>
				<th>名前</th>
				<th>職業</th>
				<th>住所</th>
				<th>年齢</th>
			</tr>
		</thead>
		<tbody>
			<tr>
				<td>はなこ</td>
				<td>医師(いし)</td>
				<td>新潟県(にいがた)</td>
				<td>38</td>
			</tr>
			<tr>
				<td>たけし</td>
				<td>海洋研究(かいようけんきゅう)</td>
				<td>岡山県(おかやま)</td>
				<td>48</td>
			</tr>
                             ・
                             ・
                             ・
		</tbody>
	</table>
</section>

via

Light Javascript Table Filter