Skip to content

Instantly share code, notes, and snippets.

@cyokodog
Last active July 7, 2020 09:17
Show Gist options
  • Save cyokodog/4978338 to your computer and use it in GitHub Desktop.
Save cyokodog/4978338 to your computer and use it in GitHub Desktop.
シンプルなテーブルフィルター jQuery プラグイン

jQuery Simple Table Filter

シンプルなテーブルフィルター jQuery プラグイン。

##使い方

フィルタ条件の入力フィールド

テキストフィールド、ラジオボタン、プルダウンメニューに対応します。

<h2>Filter</h2>
<dl class="filters">
	<dt>Class:</dt>
	<dd>
		<input name="class-filter" type="radio" value="" checked/>all
		<input name="class-filter" type="radio" value="core"/>core
		<input name="class-filter" type="radio" value="ui"/>ui
	</dd>
	<dt>Category:</dt>
	<dd>
		<input id="category-filter"/>
	</dd>
	<dt>Qty:</dt>
	<dd>
		<select id="qty-filter">
			<option>hoge</option>
			<option>fuga</option>
		</select>
	</dd>
</dl>

###データテーブル

ヘッダは thead、データは tbody に記述します。

<h2>Data</h2>
<table id="data">
	<thead>
		<tr>
			<th>No</th>
			<th>Class</th>
			<th>Category</th>
			<th>Qty</th>
		</tr>
	</thead>
	<tbody>
		<tr>
			<td>1</td>
			<td>core</td>
			<td>Ajax</td>
			<td>203</td>
		</tr>
		<tr>
			……
		</tr>
	</tbody>
</table>

###JavaScript

列番号とフィルタ入力フィールドの対応を指定してプラグインを実行します。

$('table').simpleTableFilter({
	filters : {
		1 : 'input[name=class-filter]',
		2 : '#category-filter',
		3 : '#qty-filter'
	}
});

Demo

;(function($){
$.fn.simpleTableFilter = function(option){
//オプション設定
option = $.extend({
autoFiltering : true
},option);
return this.each(function(){
//table 要素の取得
var target = $(this);
//--------------------------------------------------------------
//フィルタリング処理の実装とテーブルへのバインド
//--------------------------------------------------------------
target.on('table-filtering',function(){
//tr でループ
$(this).find('> tbody > tr').each(function(){
//一旦 tr を表示状態にする
var tr = $(this).show();
//td でループ
$(this).find('> *').each(function(index){
//対応するフィルタを取得
var filter = option.filters[index];
//フィルタの割り当てられてるか?
if(filter){
//jQuery オブジェクト化
filter = $(filter);
//td の値を小文字化して取得
var data = $(this).text().toLowerCase();
//フィルタの値を小文字化して取得
var filter_val = filter.val().toLowerCase();
//ラジオボタンの場合は選択された要素から値を取得
if(filter.prop('type') == 'radio'){
var filter_val = filter.filter(':checked').val().toLowerCase();
}
//フィルタの値が td の値に含まれてなかったら
if(data.indexOf(filter_val) < 0){
//tr を非表示にして
tr.hide();
//td のループを抜ける
return false;
}
}
});
});
});
//--------------------------------------------------------------
//条件入力フィールドに変更があったらフィルタリング処理を起動する
//--------------------------------------------------------------
//自動フィルタリングオプションが有効の場合のみバインドする
if(option.autoFiltering){
//条件入力フィールドでループ
for(var i in option.filters){
//キー入力後のフィルタリング処理を遅延実行させるためのタイマー変数
var timer;
//フィルタ条件入力時
$(option.filters[i]).on('keydown change',function(){
//直近のキー入力による実行待ちのフィルタリング処理をキャンセル
if(timer) clearTimeout(timer);
//300ms 後のフィルタリング実行を予約
timer = setTimeout(function(){
target.trigger('table-filtering');
},300);
});
}
}
//フィルタリングの実行
target.trigger('table-filtering');
});
}
})(jQuery);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment