成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導(dǎo)航首頁(yè) ? 技術(shù)教程 ? jQuery實(shí)現(xiàn)select模糊查詢(xún)(反射機(jī)制)
全站頭部文字 我要出現(xiàn)在這里
jQuery實(shí)現(xiàn)select模糊查詢(xún)(反射機(jī)制) 757 2024-02-05   

通過(guò)如下代碼就可以簡(jiǎn)單實(shí)現(xiàn)select帶模糊查詢(xún)的條件查詢(xún),具體如下jquery.select.js如下:

 (function($) {
 $.selectSuggest = function(target, data, itemSelectFunction) {
 var defaulOption = {
  suggestMaxHeight: '200px',//彈出框最大高度
  itemColor : '#000000',//默認(rèn)字體顏色
  itemBackgroundColor:'RGB(199,237,204)',//默認(rèn)背景顏色
  itemOverColor : '#ffffff',//選中字體顏色
  itemOverBackgroundColor : '#C9302C',//選中背景顏色
  itemPadding : 3 ,//item間距
  fontSize : 12 ,//默認(rèn)字體大小
  alwaysShowALL : true //點(diǎn)擊input是否展示所有可選項(xiàng)
  };
  var maxFontNumber = 0;//最大字?jǐn)?shù)
  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 = $('<div></div>'); //創(chuàng)建一個(gè)子<div>
  }
  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 = $('<div></div>'); //創(chuàng)建一個(gè)子<div>
   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如下:

 <!DOCTYPE html>
 <html lang="zh_cn">
  <head>
  <title>select.suggest</title>
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  < Bootstrap -->
  <script src="http://www.gimoo.net/t/1807/js/jquery-1.10.2.js"></script>
  <script src="http://www.gimoo.net/t/1807/js/jquery.select.js"></script>
  </head>
  <body>
  <h1>Hello, world!</h1>
  <div>
   <div>
   <div>.col-md-1
   </div>
   <div style="">
    <input id="testInput" type="text" />
   </div>
   </div>
  </div>
  < jQuery (necessary for Bootstrap's JavaScript plugins) -->
  < Include all compiled plugins (below), or include individual files as needed -->
  </body>
  <script type="text/javascript">
  var datas =[{"id":"2","text":"中國(guó)石油"}, 
  {"id":"4","text":"中國(guó)建筑"},
  {"id":"3","text":"中國(guó)移動(dòng)"},
  {"id":"5","text":"中國(guó)工商銀行"},
  {"id":"7","text":"中國(guó)鐵建"},
  {"id":"8","text":"上海汽車(chē)集團(tuán)"},
  {"id":"9","text":"中國(guó)建設(shè)銀行"},
  {"id":"10","text":"聯(lián)想集團(tuán)"}];
  var itemSelectFuntion = function(){
   alert(this.id + "," + this.innerHTML);
  };
  $.selectSuggest('testInput',datas,itemSelectFuntion);
  </script>
 </html>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持綠夏網(wǎng)。



主站蜘蛛池模板: 杨采妮郭富城床戏视频| 团结力量歌词大全图片| 3844开关电源电路图| 迎风的青春电影| 张扬导演| 霹雳俏娇娃| 妈妈帮儿子打飞机| 大时代电视剧剧情介绍| 我的新学校英语作文| 假男假女 电影| 郑中基的电影全部作品| 徐正超| cgtn英语频道在线直播观看| 八年级英语阅读理解专项训练| 台湾早期经典怀旧内衣模特走秀| 新生儿喂奶粉的量和时间| 美丽交易| 尸家重地演员表| p333的图片| 玛吉吉伦哈尔| 爱情赏味期| 绝不放弃电影| 内衣视频| 女生下体长什么样| 许华升公个人资料身高多少| 五育当中各育的地位| 欧美日韩欧美日韩| 我的世界,视频| 孤战迷城电视剧剧情分集介绍| 我爱五指山我爱万泉河| 影音先锋欧美| 遥远的你我触不可及动漫| 国产伦理女村支书| 金珠的电影全部免费观看| 声优闺蜜小涵| 在人间在线观看完整版| 被五六个女同学掏蛋| xiuren秀人网| 学生肉体还债电影| 欧美gv网站| 女女女女|

!!!站長(zhǎng)長(zhǎng)期在線(xiàn)接!!!

網(wǎng)站、小程序:定制開(kāi)發(fā)/二次開(kāi)發(fā)/仿制開(kāi)發(fā)等

各種疑難雜癥解決/定制接口/定制采集等

站長(zhǎng)微信:lxwl520520

站長(zhǎng)QQ:1737366103