このプラグインは、正規表現を使用して、検索入力に基づいてコンテンツをリアルタイムで並べ替えます。現在、スクリプトは入力と同時に検索を行っています。
コードは次のとおりです。
$.fn.simpleContentSearch = function ( options ) {
var settings = {
'active' : 'active',
'normal' : 'normal',
'searchList' : 'searchable tr',
'searchItem' : 'td',
'effect' : 'none' // fade, none
};
var base = this;
var options = $.extend(settings, options);
function startSearching(query)
{
$( '.' + settings.searchList ).each(function ()
{
$(this).children( settings.searchItem ).each(function ()
{
var elem = $(this);
if (!elem.html().match(new RegExp('.*?' + query + '.*?', 'i'))) {
if( settings.effect == 'fade' ){
$(this).parent( '.' + settings.searchList ).fadeOut();
} else {
$(this).parent( '.' + settings.searchList ).hide();
}
} else {
if( settings.effect == 'fade' ){
$(this).parent( '.' + settings.searchList ).fadeIn();
} else {
$(this).parent( '.' + settings.searchList ).show();
}
return false;
}
return;
});
});
}
return this.each(function() {
// On Blur
base.blur(function ()
{
var elem = base;
elem.removeClass().addClass(options.normal);
});
// On Focus
base.focus(function ()
{
var elem = base;
elem.removeClass().addClass(options.active);
});
//Keyup
base.keyup(function ()
{
startSearching(base.val());
});
return this;
});
}
私がやりたいのは、「text1」「text2」のようないくつかのボタンを作成し、それらをクリックすると、入力せずに「text1」を検索できるようにすることです。これを行う方法について何か提案はありますか? これがスクリプトの仕組みです:jsfiddle
ありがとうございました!