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);
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>