Select下拉列表类(支持输入模糊查询)

<HTML>   
<HEAD>   
<META http-equiv='Content-Type' content='text/html; charset=gb2312'>   
<TITLE>可输入的下拉框</TITLE>   

</HEAD>   
<BODY >   
  <Script Language="Javascript">
var j = 0;
function SelectValue(obj)
{
    var input = obj.parentNode.nextSibling;
    document.all.box2.value = obj.options[obj.selectedIndex].text;
    document.getElementById("txtSection").value=obj.options[obj.selectedIndex].value;
    alert(document.getElementById("txtSection").value);
}

function InputValue(obj)
{
    var n = 1;    
    var tmpObj;
    var src = document.all.SelectOption;
    var msg = document.all.msg;
    if(event.keyCode != 40 && event.keyCode != 38 && event.keyCode != 13){
        if(obj.value!=""){
             msg.style.display="";
             msg.innerHTML="";
             if(msg.hasChildNodes()) 
             { 
                msg.childNodes[0].parentNode.removeChild(msg.childNodes[0]); 
             }
             
             for (var i=0;i<src.length;i++){
               var selValue = document.createElement("div");
               var selText = document.createElement("div");
               selText.value = src(i).value;
               selText.innerHTML = src(i).text;          

               if (src(i).text.toLowerCase().indexOf(obj.value.toLowerCase())==0){ 
                    selText.setAttribute("id","selText"+n);
                    selText.οnmοuseοver=function (){   
                    this.style.backgroundColor='#003399';   
                    this.style.color ='#ffffff'; 
                   }
                   selText.οnmοuseοut=function (){   
                    this.style.backgroundColor='#ffffff'; 
                    this.style.color ='#000000';
                   }
                   selText.οnclick=function (){   
                    document.all.box2.value = this.innerHTML;
                    msg.style.display="none";
                    document.getElementById("txtSection").value=this.value;
                   }
                    msg.appendChild(selText);
                    n++;
               }
             }
        }
        else {
            document.all.msg.style.display="none";
        }
    }
    else {
        //press down key
        if(event.keyCode==40){
            j++;
            for (var i=0; i<src.length; i++)
            {
                tmpObj = document.getElementById("selText"+i);
                if(tmpObj != null){
                    tmpObj.style.backgroundColor='#ffffff'; 
                    tmpObj.style.color ='#000000';
                }                
            }
            tmpObj = document.getElementById("selText"+j);
            if(tmpObj != null){
                tmpObj.style.backgroundColor='#003399';   
                tmpObj.style.color ='#ffffff'; 
            }else{
                j = 0;
            }            
        }
        //press up key
        if (event.keyCode==38){
            j--;
            for (var i=0; i<src.length; i++)
            {
                tmpObj = document.getElementById("selText"+i);
                if(tmpObj != null){
                    tmpObj.style.backgroundColor='#ffffff'; 
                    tmpObj.style.color ='#000000';
                }                
            }
            tmpObj = document.getElementById("selText"+j);
            if(tmpObj != null){
                tmpObj.style.backgroundColor='#003399';   
                tmpObj.style.color ='#ffffff'; 
            }else{
                j = 2;
            }        
        }
        //press enter key
        if (event.keyCode==13){
            tmpObj = document.getElementById("selText"+j);
            document.all.box2.value = tmpObj.innerHTML;
            msg.style.display="none";
            document.getElementById("txtSection").value=tmpObj.value;
        }
    }
}

function SelMatch(src)
{
    var currSel = document.all.box2.value;
    for (var i=0;i<src.length;i++){
        if (src(i).text==currSel)
        {
            src.options(i).selected = true;
        }        
    }
}

function NoMsg()
{    
    if(document.activeElement.id=="msg") 
        return false; 
    else
        document.all.msg.style.display='none';
}


  </Script>
 <TABLE border=0 cellPadding=1 cellSpacing=0 width="100%">
   

     <TR> 
      <TD width="24%"><font face="Arial" size="2">Section</font></TD>
      <TD COLSPAN=3 width="76%"> 

<div style="position:relative;">   
<span style="margin-left:230px;width:18px;overflow:hidden;">  

<select style="HEIGHT: 22px; WIDTH: 250px; margin-left:-232px;" οnchange="SelectValue(this)" οnclick="SelMatch(this)"  id="SelectOption" name="SelectOption" >   
  <OPTION value='ALL' Selected>ALL</OPTION>
<OPTION value='0TEST1'>0TEST1 = Testing 1
<OPTION value='0TEST1'>0TEST2 = Testing 1
<OPTION value='0TEST1'>0TEST3 = Testing 1
<OPTION value='SECTION'>SECTION = Section Description XXXXX AAA
</OPTION>  
</select></span>
<input name="box2" id="box2" style="width:230px;position:absolute;left:0px;" οnkeyup="InputValue(this)"  οnblur="NoMsg()" οnfοcus="this.select();InputValue(this)" value="0" >   
<div id="msg" style="border:1px  solid green;  font-size :14PX;white-space:nowrap;overflow:hidden;
width:230px;position:absolute;left:0px;top:20px;display:none"></div>
</div>

    <Input Type="Hidden" Name="txtSection" id="txtSection">
      </TD>
    </TR>
    </TABLE>
<p>

</BODY></HTML> 

  

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值