亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JSuggest自動匹配下拉框使用方法(示例代碼)

2019-11-20 21:22:09
字體:
來源:轉載
供稿:網友

1.下載jquery-latest.js,JSuggest.js和JSuggest.css

JSuggest.js源代碼如下

復制代碼 代碼如下:

/**
*
* Description : JSuggest 下拉提示框
*/

function JSuggest(){

// DIV下拉框
this.div = null;

// DIV下的ul
this.ul = null;

// 文本輸入框
this.input = null;

// 當前DIV所選的LI對象
this.current_li = null;

/**
* 隱藏下拉提示框
*/
this.hide = function(){
this.div.style.visibility = "hidden";
}

/**
* 顯示下拉提示框
*/
this.show = function(){
this.div.style.visibility = "visible";
}

/**
* 下拉提示框狀態
*/
this.status = function(){
if (this.div.style.visibility == "visible"){
return true;
}
return false;
}

/**
* 設置當前DIV所選的LI
*/
this.setCurrent_li = function(li, obj){
var co = obj.current_li;
if (co != null){
co.className = "";
}
li.className = "li_index";
obj.current_li = li;
}

/**
* 初始化Suggest
*
* input_id : 輸入框的ID
* defHeight: 下拉提示框的高(不提供也可以)
*/
this.init = function(input_id, defHeight){
this.input = document.getElementById(input_id);
//this.input.autocomplete = "off";
var left = this.input.offsetLeft;
var top = this.input.offsetTop;
var width = this.input.offsetWidth;
var height = this.input.offsetHeight;
var p=this.input.offsetParent;
   while(p!= null){
left+=p.offsetLeft;
top+=p.offsetTop;
p=p.offsetParent;
   }
top+= height;
if(defHeight==null || defHeight==0){
height = 150;
}else{
height = defHeight;
}
this.input.value = "";
var obj = this;
this.input.onkeydown = function(evt){
obj.onkeydown(evt, obj);
}
this.div = document.createElement("div");
this.div.style.width = width + "px";
this.div.style.height = height + "px";
this.div.style.left = left + "px";
this.div.style.top = top + "px";
this.ul = document.createElement("ul");
this.div.appendChild(this.ul);
this.div.className = "jsuggest";
document.body.appendChild(this.div);
}

/**
* 移除DIV下UL中所有的LI
*/
this.remove = function(){
this.current_li = null;
while(this.removeLI());
}

/**
* 移除DIV下UL中的LI
*/
this.removeLI = function(){
var node = this.ul.childNodes;
for(var n in node){
if (node[n] != null && node[n].nodeName == "LI"){
// alert(node[n].innerHTML);
this.ul.removeChild(node[n]);
return true;
}
}
return false;
}

/**
* 在DIV中創建LI
*/
this.create = function(items){
this.remove();

var li_item = items.split(",");

for(var i in li_item){
//alert(li_item[i]);
var li = document.createElement("li");
li.innerHTML = li_item[i];

var obj = this;
li.onmousedown = function(){
obj.onmousedown(this, obj);
}
li.onmouseover = this.onmouseover;
li.onmouseout = this.onmouseout;

this.ul.appendChild(li);
}
this.show();
}

/**
* 文本框按下事件
*/
this.onkeydown = function(evt, obj){
if (!obj.status()){
return false;
}

if (!evt && window.event)
{
evt = window.event;
}

var key = evt.keyCode;

//var KEYUP = 38;
//var KEYDOWN = 40;
//var KEYENTER = 13;
var ob = obj;
if (key == 38){
obj.upKeySelected();
}else if (key == 40){
obj.downKeySelected();
}else if (key == 13 || key == 27){
obj.hide();
}
}

this.getCurrentLiIndex = function(){
if(this.current_li == null){
return -1;
}
var node = this.ul.childNodes;
for(var n in node){
if (node[n].nodeName == "LI"){
if(node[n] == this.current_li){
return n;
}
}
}
}

this.getLi = function(index){
var node = this.ul.childNodes;
for(var n in node){
if (node[n].nodeName == "LI" && n == index){
this.setCurrent_li(node[n], this);
return node[n];
}
}
}

this.upKeySelected = function(){
var num = this.getCurrentLiIndex();
if (num != -1 && num > 0){
num--;
var node = this.getLi(num);
this.setCurrent_li(node, this);
this.input.value = node.innerHTML;
}
}

this.downKeySelected = function(obj){
var num = this.getCurrentLiIndex();
if (num == -1){
num = 0;
}else {
num++;
if (num >= this.ul.childNodes.length)return false;
}
var node = this.getLi(num);
this.setCurrent_li(node, this);
this.input.value = node.innerHTML;
}

/**
* DIV鼠標按下事件
*/
this.onmousedown = function(thiz, obj){
obj.setCurrent_li(thiz, obj);
obj.input.value = thiz.innerHTML;
obj.hide();
}

/**
* DIV鼠標移動事件
*/
this.onmouseover = function(){
if (this.className != "li_index"){
this.className = "li_check";
}
}

/**
* DIV鼠標移出事件
*/
this.onmouseout = function(){
if (this.className == "li_check"){
this.className = "";
}
}

}

var jsuggest = new JSuggest();


2.jsp頁面
復制代碼 代碼如下:

<input id="text" name="text" type="text"  onkeyup="go(event, this.value);"/>

<script type="text/javascript">   

 j(document).ready(function(){
  // 初始化JSUGGEST
  jsuggest.init("text");
  //或者用下面的方法,設置下拉框高度
  //jsuggest.init("text",200);
 })

 
 function go(event, value){
     event= event ? event : (window.event ? window.event : arguments[0]);
     var url = "url?suggestInput="+encodeURIComponent(value);//url是具體的action或jsp地址等,返回值是以逗號分隔的字符串
  goSuggestInput(event,url,value);
 }

 

function goSuggestInput(evnet,url,value){
        if (value == ""){
         // 如果輸入框為空隱藏下拉框
         jsuggest.hide();
      return false;   
        }

     // 確保evt是一個有效的事件  
  if (!evnet && window.event)
  {
   evnet = window.event;
  }
  var key = evnet.keyCode;
  if (key == 38 || key == 40 || key == 13 || key == 27){
   return false;
  }

  j.ajax({
   type: "post",
         url:url,
   dataType: "text",
   cache: "false",

   beforeSend: function(XMLHttpRequest){
   },
   success: function(data, textStatus){
    // 對下拉框添加數據
    jsuggest.create(data);

   },
   complete: function(XMLHttpRequest, textStatus){

   },
   error: function(){
    alert("對不起,服務器忙!");
   }
  });
 }

</script>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩在线国产精品| 国产噜噜噜噜噜久久久久久久久| 国产日韩在线亚洲字幕中文| 尤物九九久久国产精品的分类| 欧美另类精品xxxx孕妇| 国产va免费精品高清在线观看| 浅井舞香一区二区| 亚洲全黄一级网站| 日韩女优人人人人射在线视频| 亚洲欧美国产日韩中文字幕| 久久天天躁夜夜躁狠狠躁2022| 亚洲aⅴ日韩av电影在线观看| 亚洲美女视频网站| 成人夜晚看av| 亚洲欧洲xxxx| 日本精品在线视频| 国产亚洲激情在线| 中文字幕亚洲一区二区三区五十路| 欧美电影院免费观看| 国产国语videosex另类| 欧美日韩另类字幕中文| 91福利视频网| 欧美老女人性生活| 日韩第一页在线| 欧美激情喷水视频| 久久免费观看视频| 在线精品国产成人综合| 国产亚洲精品久久久久久| 国内精品在线一区| 精品在线欧美视频| 国产亚洲精品一区二555| 国产精品91在线观看| 成人午夜高潮视频| 国产中文欧美精品| 亚洲精品aⅴ中文字幕乱码| 色婷婷av一区二区三区在线观看| 欧美成人中文字幕| 欧美一级淫片丝袜脚交| 国产亚洲一区二区在线| 欧美黄色片在线观看| 欧美在线影院在线视频| 国产激情视频一区| 国产精品久久在线观看| 久久精品视频va| 久久久久久高潮国产精品视| 日韩在线视频国产| 精品久久久久久中文字幕大豆网| 欧美区二区三区| 久久视频免费观看| 福利精品视频在线| 国产精品羞羞答答| 欧美孕妇性xx| 国产免费一区二区三区在线观看| 欧美精品精品精品精品免费| 午夜免费久久久久| 国产精品91免费在线| 亚洲网站在线看| 福利一区视频在线观看| 国产一区二区黑人欧美xxxx| 日韩有码片在线观看| 欧美理论片在线观看| 欧美国产日韩一区二区在线观看| 51精品在线观看| 精品国产电影一区| 国产精品视频网址| 全球成人中文在线| 国产精品美女呻吟| 国产在线视频91| 欧美多人乱p欧美4p久久| 中文字幕久久亚洲| 国产精品久久久久不卡| 亚洲成人黄色在线观看| 欧美色道久久88综合亚洲精品| 日韩欧美国产成人| 国产成人激情视频| 欧美激情在线播放| 精品亚洲aⅴ在线观看| 国产一区二区三区丝袜| 欧美亚洲在线观看| 欧美一级大片在线观看| 国产精品亚洲аv天堂网| 国产精品99久久久久久白浆小说| 国产一区视频在线播放| 国产一区二区在线免费视频| 日本免费在线精品| 欧美电影免费观看高清完整| 91系列在线播放| 亚洲国产小视频在线观看| 成人午夜小视频| 欧美在线视频免费| 92版电视剧仙鹤神针在线观看| 亚洲国产精品一区二区久| 欧美亚州一区二区三区| 一区二区亚洲欧洲国产日韩| 午夜剧场成人观在线视频免费观看| 国产成人精彩在线视频九色| 国产成人精品a视频一区www| 国产精品爱久久久久久久| 精品国产一区二区三区久久狼5月| 国产精品久久久久91| 欧美精品在线免费| 亚洲成av人片在线观看香蕉| 福利视频导航一区| 欧美日韩一区二区在线播放| 久久久精品免费| 欧美国产日韩一区二区三区| 69av视频在线播放| 久久的精品视频| 日本高清不卡的在线| 5566日本婷婷色中文字幕97| 欧美黄色片在线观看| 欧美一级电影久久| 国产精品久久久久秋霞鲁丝| 欧美黑人一级爽快片淫片高清| 98精品国产自产在线观看| 欧美成人黑人xx视频免费观看| 69国产精品成人在线播放| 久久久久久久av| 亚洲福利精品在线| 日韩毛片在线观看| 色噜噜久久综合伊人一本| 亚洲高清久久久久久| 视频在线观看99| 精品久久久国产精品999| 亚洲第一国产精品| 国产一区二中文字幕在线看| 91精品视频免费| 国产精品嫩草影院一区二区| 欧美成在线观看| 亚洲国内高清视频| 久久久久久久久久久网站| 国产激情久久久久| 成人免费自拍视频| 欧美中文字幕第一页| 亚洲aⅴ日韩av电影在线观看| 日韩小视频在线| 精品久久久视频| 俺也去精品视频在线观看| 欧美精品一区二区三区国产精品| 欧美黄色片在线观看| 国产精品嫩草影院一区二区| 日韩av中文字幕在线播放| 热99久久精品| 日韩黄色av网站| 亚洲社区在线观看| 2023亚洲男人天堂| 全色精品综合影院| 国产亚洲激情在线| 狠狠色香婷婷久久亚洲精品| 8x拔播拔播x8国产精品| 亚洲精品视频播放| 91在线中文字幕| 欧美激情精品久久久久久免费印度| 色综合91久久精品中文字幕| 日韩欧美主播在线| 亚洲视频999| 国产精品久久久久秋霞鲁丝| 欧美性xxxx极品高清hd直播| 日韩成人在线视频| 国产视频久久久久久久| 亚洲色图激情小说| 中文字幕亚洲欧美日韩在线不卡| 日韩免费精品视频| 69国产精品成人在线播放|