jQuery实现select模糊查询反射机制

通过如下代码就可以简单实现select带模糊查询的条件查询,具体如下jquery.select.js如下:

rush:js;"> (function($) { $.selectSuggest = function(target,data,itemSelectFunction) { var defaulOption = { suggestMaxHeight: '200px',//弹出框最大高度 itemColor : '#000000',//认字体颜色 itemBackgroundColor:'RGB(199,237,204)',//认背景颜色 itemOverColor : '#ffffff',//选中字体颜色 itemOverBackgroundColor : '#C9302C',//选中背景颜色 itemPadding : 3,//item间距 fontSize : 12,//认字体大小 alwaysShowALL : true //点击input是否展示所有可选项 }; var maxFontNumber = 0;//最大字数 var currentItem; var suggestContainerId = target + "-suggest"; var suggestContainerWidth = $('#' + target).innerWidth(); var suggestContainerLeft = $('#' + target).offset().left; var suggestContainerTop = $('#' + target).offset().top + $('#' + target).outerHeight(); var showClickTextFunction = function() { $('#' + target).val(this.innerText); currentItem = null; $('#' + suggestContainerId).hide(); } var suggestContainer; if ($('#' + suggestContainerId)[0]) { suggestContainer = $('#' + suggestContainerId); suggestContainer.empty(); } else { suggestContainer = $('
'); //创建一个
} suggestContainer.attr('id',suggestContainerId); suggestContainer.attr('tabindex','0'); suggestContainer.hide(); var _initItems = function(items) { suggestContainer.empty(); var itemHight=0; for (var i = 0; i < items.length; i++) { if(items[i].text.length > maxFontNumber){ maxFontNumber = items[i].text.length; } var suggestItem = $('
'); //创建一个
suggestItem.attr('id',items[i].id); suggestItem.append(items[i].text); suggestItem.css({ 'padding':defaulOption.itemPadding + 'px','white-space':'Nowrap','cursor': 'pointer','background-color': defaulOption.itemBackgroundColor,'color': defaulOption.itemColor }); suggestItem.bind("mouSEOver",function() { $(this).css({ 'background-color': defaulOption.itemOverBackgroundColor,'color': defaulOption.itemOverColor }); currentItem = $(this); }); suggestItem.bind("mouSEOut",function() { $(this).css({ 'background-color': defaulOption.itemBackgroundColor,'color': defaulOption.itemColor }); currentItem = null; }); suggestItem.bind("click",showClickTextFunction); suggestItem.bind("click",itemSelectFunction); suggestItem.appendTo(suggestContainer); suggestContainer.appendTo(document.body); } } var inputChange = function() { var inputValue = $('#' + target).val(); inputValue = inputValue.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g,"\\$&"); var matcher = new RegExp(inputValue,"i"); return $.grep(data,function(value) { return matcher.test(value.text); }); } $('#' + target).bind("keyup",function() { _initItems(inputChange()); }); $('#' + target).bind("blur",function() { if(!$('#' + suggestContainerId).is(":focus")){ $('#' + suggestContainerId).hide(); if (currentItem) { currentItem.trigger("click"); } currentItem = null; return; } }); $('#' + target).bind("click",function() { if (defaulOption.alwaysShowALL) { _initItems(data); } else { _initItems(inputChange()); } $('#' + suggestContainerId).removeAttr("style"); var tempWidth = defaulOption.fontSize*maxFontNumber + 2 * defaulOption.itemPadding + 30; var containerWidth = Math.max(tempWidth,suggestContainerWidth); var h = this.scrollHeight; $('#' + suggestContainerId).css({ 'border': '1px solid #ccc','max-height': '100px','top': suggestContainerTop,'left': suggestContainerLeft,'width': containerWidth,'position': 'absolute','font-size': defaulOption.fontSize+'px','font-family':'Arial','z-index': 99999,'background-color': '#FFFFFF','overflow-y': 'auto','overflow-x': 'hidden','white-space':'Nowrap' }); $('#' + suggestContainerId).show(); }); _initItems(data); $('#' + suggestContainerId).bind("blur",function() { $('#' + suggestContainerId).hide(); }); } })(jQuery);

html如下:

rush:xhtml;"> select.suggest <Meta name="viewport" content="width=device-width,initial-scale=1.0">

Hello,world!

.col-md-1