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

首頁 > 學院 > 開發設計 > 正文

下拉菜單輸入,根據輸入內容自動定位

2019-11-18 20:15:59
字體:
來源:轉載
供稿:網友
下拉菜單支持輸入,并根據輸入內容自動定位:

參考:演員發表于 10/23/2001 8:58:16 AM 的文章 “羅亭的可輸入下拉框的解密簡化版.”,在此特別感謝相關人等。

本文為這個下拉框增加了一點小小的功能:輸入能夠定位在已有的選擇框內。還有一個缺點,各位給改改:輸入的時候不能夠自動拉開選擇框,怎么辦?

function getLeftPostion( theObj )
{
  var pos = 0;
  while ( theObj != null )
  {
    pos += theObj.offsetLeft;
    //get the Object which contain theObj.
    theObj = theObj.offsetParent;
  }
  return pos;
}
function getTopPostion( theObj )
{
  var pos = 0;
  while ( theObj != null )
  {
    pos += theObj.offsetTop;
    //get the Object which contain theObj.
    theObj = theObj.offsetParent;
  }
  return pos;
}
function checkVersion()
{
  var isBadVersion=true;
  var curVer=navigator.appVersion;
  var pos=parseInt(curVer.indexOf("MSIE"));
  if (pos>=1)
  {
    var intVer=parseInt(curVer.charAt(pos+5));
    if (intVer>=5)
    { isBadVersion=false;}
  }
  if (isBadVersion)
  {
    var msg="This page may not be displayed PRoperly:/n"+
            " This product requires Microsoft Internet Explorer 5 or later browser only.";
    alert(msg);
  }
}

//check the browser version
checkVersion();

// the array of comboBoies
theArray = new Array();

function combobox(objId, objHandler)
{
    this.comObj = document.all[objId];
    this.comObj.selectedIndex = -1;
    this.getValue = getValue;
    this.doResize = doResize;
    this.doChange = doChange;
    this.loseFocus = loseFocus;
    this.doSelectIdx = doSelectIdx;
    this.focus = focus;
    this.keyPress = keyPress;
    this.change = change;

    var strMsg="";

//------------------------------------------------------------------------------------------------------
// create the text object
//------------------------------------------------------------------------------------------------------
    var txtObjIdName = objId + "_text";

    if (document.all[txtObjIdName] != null)
    {
        strMsg="The following id: '" + txtObjIdName +"' is used internally by the Combo Box!/r/n"+
           "Use of this id in your page may cause malfunction. Please use another id for your controls.";
        alert(strMsg);
    }

    var txtInner = "<INPUT type='text' id=" + txtObjIdName + " name=" + txtObjIdName + " onblur='" + objHandler + ".loseFocus()' " + " onkeyup='" + objHandler + ".keyPress()'" +  " onchange='" + objHandler + ".keyPress()'" + " style='display: none; position: absolute' value='' >";

    this.comObj.insertAdjacentHTML("afterEnd", txtInner);

    this.txtObj = document.all[txtObjIdName];

//------------------------------------------------------------------------------------------------------
// end
//------------------------------------------------------------------------------------------------------

    this.beResizing = false;
    this.doResize();
    theArray[theArray.length] = this;
}

function loseFocus()
{
    var theComObj = this.comObj;
    var theTxtObj = this.txtObj;
    var i;
    theComObj.selectedIndex = -1;

    if (theTxtObj.value == "")
    {
        return;
    }

    var optLen = theComObj.options.length;
    for (i=0; i<optLen; i++)
    {
        var comVal = theComObj.options[i].text;
        var txtVal = theTxtObj.value;

        if (comVal == txtVal)
        {
            theComObj.selectedIndex = i;
            return;
        }
    }
}

function doResize()
{
    if (!this.beResizing)
    {
        this.beResizing = true;
        this.txtObj.style.display="none";
        this.comObj.style.position="static";
        this.txtObj.style.posLeft = getLeftPostion(this.comObj);
        this.txtObj.style.posTop = getTopPostion(this.comObj) + 1;
        this.txtObj.style.posWidth = this.comObj.offsetWidth - 16;
        this.txtObj.style.posHeight = this.comObj.offsetHeight;
        this.comObj.style.position ="absolute";
        this.comObj.style.posLeft = this.txtObj.style.posLeft;
        this.comObj.style.posTop = this.txtObj.style.posTop;
        this.offWidth = this.comObj.offsetWidth;
    
        var strRect = "rect(0 "+(this.comObj.offsetWidth)+" "+ this.comObj.offsetHeight + " "+(this.txtObj.style.posWidth - 2 )+")";

        this.comObj.style.clip = strRect;
        this.txtObj.style.display="";
        this.beResizing = false;
    }
}

function doChange()
{
    var idx = this.comObj.selectedIndex;
    var opt = this.comObj.options[idx];
    this.txtObj.value = opt.text;
    this.txtObj.focus();
    this.txtObj.select();
    this.comObj.selectedIndex=-1;
}

function getValue()
{
    return this.txtObj.value;
}

function doSelectIdx(i)
{
    var optLen = this.comObj.options.length;

    if ((i >=0) && (i < optLen))
    {
        this.comObj.selectedIndex = i;
        this.txtObj.value = this.comObj.options[i].text;
        return;
    }
    this.txtObj.value = "";
}


function focus()
{
    this.txtObj.focus();
}

/*resize all combobox when window be resized*/
function resetAllSize()
{
    var i;
    for (i=0; i < theArray.length; i++)
    {
        theArray[i].doResize();
    }
}
////////////////定位函數開始,我加的///////////////
function keyPress()
{
    var txtStr;
    var comStr;
    var maxInt = 0;
    var defInt = 0;
    var defJ;
    txtStr = this.txtObj.value;
    //document.form1.test.value=txtStr;
    var j;
    for(j=0;j<this.comObj.options.length;j++)
    {
        comStr = this.comObj.options[j].text;
        var m;
        for(m=0;m<txtStr.length+1;m++)
        {
            if(txtStr.charCodeAt(m) != comStr.charCodeAt(m))
            {
                maxInt = m;
                break;
            }
        }
        if (defInt < maxInt)
        {
            defInt = maxInt;
            defJ = j;
        }
    }
    this.comObj.selectedIndex = defJ;
}



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩网站免费观看| 国产国语刺激对白av不卡| 欧美精品videos性欧美| 亚洲欧美日韩中文在线| 国产丝袜精品视频| 欧美大片欧美激情性色a∨久久| 一个人看的www久久| 久久久精品欧美| 亚洲欧美激情四射在线日| 久久综合伊人77777| 亚洲女人天堂视频| 亚洲欧美日韩网| 日韩av观看网址| 最近中文字幕mv在线一区二区三区四区| 久久精品国产精品亚洲| 国产精品丝袜久久久久久高清| 成人综合国产精品| 国产成人精品综合久久久| 亚洲人成在线观看网站高清| 国产精品日日做人人爱| 91久久久久久| 91高潮精品免费porn| 精品久久久av| 日韩在线视频免费观看高清中文| 欧美色欧美亚洲高清在线视频| 国产成人精品av| 日韩视频亚洲视频| 亚洲精品wwwww| 亚洲免费视频一区二区| 欧美在线日韩在线| 欧美大人香蕉在线| 九九热这里只有精品6| 欧美黑人一区二区三区| 欧美性猛交xxxx富婆弯腰| 亚洲图中文字幕| 国产免费一区二区三区香蕉精| 91国语精品自产拍在线观看性色| 国产成人黄色av| 欧美成人精品xxx| 欧美中文在线视频| 欧美亚洲国产日韩2020| 国产午夜精品视频| 国产亚洲精品综合一区91| 精品久久久免费| 亚洲国产欧美自拍| 欧美另类在线观看| 免费av一区二区| 一区二区三区四区视频| 午夜免费日韩视频| 成年无码av片在线| 亚洲国产中文字幕久久网| 久久综合亚洲社区| 一区二区三区 在线观看视| 九九热视频这里只有精品| 欧美电影免费观看电视剧大全| 久久成人人人人精品欧| 国产精品爽黄69天堂a| 伊人久久久久久久久久| 综合136福利视频在线| 久久综合电影一区| 国产精品爽爽ⅴa在线观看| 日本aⅴ大伊香蕉精品视频| 日韩精品免费在线| 久久成人亚洲精品| 最好看的2019年中文视频| 久久人体大胆视频| 精品一区二区亚洲| 欧洲日韩成人av| 日韩中文字幕免费看| 欧美大荫蒂xxx| 色婷婷亚洲mv天堂mv在影片| 欧美午夜片在线免费观看| 久久精品国产一区二区三区| 亚洲午夜小视频| 国产98色在线| 国产精品国模在线| 国产精品视频精品| www.国产精品一二区| 色悠悠久久久久| 992tv在线成人免费观看| 国产精品精品一区二区三区午夜版| 日韩av免费在线| 国产这里只有精品| 91视频88av| 国产美女91呻吟求| 亚洲天堂久久av| 欧洲日韩成人av| 欧美日韩性视频| www.久久色.com| 亚洲精选一区二区| 精品呦交小u女在线| 欧美精品久久久久久久久| 欧美激情xxxx性bbbb| 国产午夜精品美女视频明星a级| 欧美色道久久88综合亚洲精品| 欧美激情综合色综合啪啪五月| 欧美乱大交xxxxx另类电影| 亚洲18私人小影院| 亚洲国产精品女人久久久| 国自在线精品视频| 国产成人久久久| 在线精品高清中文字幕| www.亚洲人.com| 欧美成人精品在线播放| 欧美在线免费观看| 免费av一区二区| 亚洲国产精品久久| 91久久久久久久一区二区| 色www亚洲国产张柏芝| 色偷偷88888欧美精品久久久| 亚洲男女自偷自拍图片另类| 亚洲黄色有码视频| 日本aⅴ大伊香蕉精品视频| 国产精品爽黄69天堂a| 国产精品扒开腿做爽爽爽视频| 久久躁狠狠躁夜夜爽| 久久综合亚洲社区| 国产suv精品一区二区三区88区| 日韩av在线播放资源| 久久成年人免费电影| 国产美女主播一区| 国产一区香蕉久久| 久久久久久12| 国产一区二区三区精品久久久| 欧美一区二粉嫩精品国产一线天| 亚洲欧洲xxxx| 久久精品中文字幕电影| 久久久亚洲欧洲日产国码aⅴ| 国产成人精品免费视频| 91干在线观看| 国产+成+人+亚洲欧洲| 亚洲精品aⅴ中文字幕乱码| 国产精品久久久久久久9999| 久久久女人电视剧免费播放下载| 亚洲第一福利在线观看| 国产成人精品av| 亚洲自拍偷拍在线| 2019中文字幕在线观看| 中文在线资源观看视频网站免费不卡| 成人免费视频在线观看超级碰| 青青草原成人在线视频| 精品国产成人在线| 97视频在线观看成人| 久久精品影视伊人网| 国产精品69精品一区二区三区| 成人精品视频在线| 国语对白做受69| 国产99久久久欧美黑人| 国产999精品久久久| 国产精品精品国产| 91精品久久久久久久久久| 亚洲aⅴ男人的天堂在线观看| 亚洲美女精品久久| 亚洲欧美中文字幕在线一区| 国产欧美精品xxxx另类| 国产精品av网站| 亚洲自拍小视频免费观看| 日韩av在线导航| 色系列之999| 日韩成人在线视频网站| 精品成人av一区| 中文字幕在线亚洲| 欧美日韩一区二区免费在线观看| 日韩美女免费观看|