茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    onclick和onblur沖突問(wèn)題的快速解決方法
    來(lái)源:易賢網(wǎng) 閱讀:1167 次 日期:2016-07-06 13:46:59
    溫馨提示:易賢網(wǎng)小編為您整理了“onclick和onblur沖突問(wèn)題的快速解決方法”,方便廣大網(wǎng)友查閱!

    下面小編就為大家?guī)?lái)一篇onclick和onblur沖突問(wèn)題的快速解決方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考

    新浪首頁(yè)的搜索框里面有一個(gè)使用ajax的下拉框。我們需要實(shí)現(xiàn)一個(gè)點(diǎn)擊下拉框里面的一項(xiàng),讓搜索框里面的值變成這一項(xiàng),同時(shí)下拉框消失的效果,但同時(shí)在點(diǎn)擊其他地方的時(shí)候,這個(gè)下拉框也要消失。大致如圖:

    名單

    我們同時(shí)使用onblur和onclick來(lái)使下拉框隱藏,但是更大的問(wèn)題出現(xiàn)了,這兩個(gè)功能相沖突,onblur過(guò)于強(qiáng)悍,根本沒(méi)有onclick方法實(shí)現(xiàn)的機(jī)會(huì),搜索框無(wú)法獲取點(diǎn)擊項(xiàng)的內(nèi)容。這個(gè)就是我們想要解決的onclick和onblur沖突問(wèn)題。

    對(duì)應(yīng)這個(gè)問(wèn)題,這里我們介紹兩種解決辦法:

    1. 使用setTimeout來(lái)使onblur時(shí)間延期執(zhí)行,使onclick執(zhí)行完后再執(zhí)行onblur。(其中setTimeout的時(shí)間設(shè)定應(yīng)該在100ms以上,否則依舊不行)示例代碼如下:

    <!DOCTYPE html>

    <html>

    <head lang="en">

      <meta charset="UTF-8">

      <title></title>

      <style>

        *{ margin: 0; padding: 0; list-style: none; }

        form{

          width:500px;

          margin:0 auto;

          position:relative;

          zoom:1;

        }

        form:after{

          clear:both;

          content:"";

          display:block;

        }

        .text{

          float:left;

          border:1px solid #cccccc;

          padding-left:14px;

          width:300px;

          height:34px;

          line-height:34px;

          font-size:14px;

        }

        .button{

          width:50px;

          height:34px;

          border:1px solid #cccccc;

          line-height:34px;

          font-size:14px;

          color:#ffffff;

          background:#ff8400;

        }

        ul{

          position:absolute;

          top:36px;

          left:0;

          width:300px;

          border-right:1px solid #cccccc;

          border-left:1px solid #cccccc;

          background:green;

          display:none;

        }

        li{

          font-size:14px;

          line-height:34px;

          height:34px;

          color:#000000;

          border-bottom:1px solid #cccccc;

        }

        li:hover{

          background:yellow;

          color:red;

          cursor:pointer;

        }

      </style>

      <script>

        window.onload=function(){

          var oText=document.getElementById('text');

          var oUl=document.getElementById('ul');

          var aLi=oUl.getElementsByTagName('li');

          var timer=null;

          oText.onfocus=function(){

            this.value='';

            oUl.style.display='block';

            for(var i=0;i<aLi.length;i++){

              aLi[i].onclick=function(){

                clearTimeout(timer);

                oText.value=this.innerHTML;

                oUl.style.display='none';

              };

            }

          };

          oText.onblur=function(){

            timer=setTimeout(function(){

              oUl.style.display='none';

              if(!oText.value){

                oText.value='請(qǐng)輸入關(guān)鍵字';

              }

            },120);

          };

        };

      </script>    

    </head>

    <body>

    <form>

      <input type="text" value="請(qǐng)輸入關(guān)鍵字" id="text" class="text"/>

      <input type="button" value="搜索" class="button"/>

      <ul id="ul">

        <li>返回窗口是否已被關(guān)閉</li>

        <li>返回窗口的文檔顯示區(qū)的高度</li>

        <li>返回窗口的文檔顯示區(qū)的寬度。</li>

        <li>設(shè)置或返回窗口的名稱。</li>

        <li>返回窗口的外部高度。</li>

      </ul>

    </form>

    </body>

    </html>

    2. 使用document.onmousedown來(lái)代替onblur實(shí)現(xiàn)隱藏下拉框功能

    <!DOCTYPE html>

    <html>

    <head lang="en">

      <meta charset="UTF-8">

      <title></title>

      <style>

        *{ margin: 0; padding: 0; list-style: none; }

        form{

          width:500px;

          margin:0 auto;

          position:relative;

          zoom:1;

        }

        form:after{

          clear:both;

          content:"";

          display:block;

        }

        .text{

          float:left;

          border:1px solid #cccccc;

          padding-left:14px;

          width:300px;

          height:34px;

          line-height:34px;

          font-size:14px;

        }

        .button{

          width:50px;

          height:34px;

          border:1px solid #cccccc;

          line-height:34px;

          font-size:14px;

          color:#ffffff;

          background:#ff8400;

        }

        ul{

          position:absolute;

          top:36px;

          left:0;

          width:300px;

          border-right:1px solid #cccccc;

          border-left:1px solid #cccccc;

          background:green;

          display:none;

        }

        li{

          font-size:14px;

          line-height:34px;

          height:34px;

          color:#000000;

          border-bottom:1px solid #cccccc;

        }

        li:hover{

          background:yellow;

          color:red;

          cursor:pointer;

        }

      </style>

      <script>

        window.onload=function(){

          var oText=document.getElementById('text');

          var oUl=document.getElementById('ul');

          var aLi=oUl.getElementsByTagName('li');

          var timer=null;

          oText.onfocus=function(){

            this.value='';

            oUl.style.display='block';

            for(var i=0;i<aLi.length;i++){

              aLi[i].onclick=function(){

                clearTimeout(timer);

                oText.value=this.innerHTML;

                oUl.style.display='none';

              };

            }

          };

          document.onmousedown=function(ev){

            var oEvent=ev||event;

            var target=oEvent.target||oEvent.srcElement;

              if(target.parentNode!==oUl&&target!==oText){

                oUl.style.display='none';

              }

          };

          oText.onblur=function(){

            if(!oText.value){

              oText.value='請(qǐng)輸入關(guān)鍵字';

            }  

          };

        };

      </script>    

    </head>

    <body>

    <form>

      <input type="text" value="請(qǐng)輸入關(guān)鍵字" id="text" class="text"/>

      <input type="button" value="搜索" class="button"/>

      <ul id="ul">

        <li>返回窗口是否已被關(guān)閉</li>

        <li>返回窗口的文檔顯示區(qū)的高度</li>

        <li>返回窗口的文檔顯示區(qū)的寬度。</li>

        <li>設(shè)置或返回窗口的名稱。</li>

        <li>返回窗口的外部高度。</li>

      </ul>

    </form>

    </body>

    </html>

    以上這篇onclick和onblur沖突問(wèn)題的快速解決方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考

    更多信息請(qǐng)查看網(wǎng)絡(luò)編程
    易賢網(wǎng)手機(jī)網(wǎng)站地址:onclick和onblur沖突問(wèn)題的快速解決方法
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2026上岸·考公考編培訓(xùn)報(bào)班

    • 報(bào)班類型
    • 姓名
    • 手機(jī)號(hào)
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專用圖標(biāo)