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

下面小編就為大家?guī)硪黄猳nclick和onblur沖突問題的快速解決方法。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考

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

名單

我們同時使用onblur和onclick來使下拉框隱藏,但是更大的問題出現(xiàn)了,這兩個功能相沖突,onblur過于強悍,根本沒有onclick方法實現(xiàn)的機會,搜索框無法獲取點擊項的內(nèi)容。這個就是我們想要解決的onclick和onblur沖突問題。

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

1. 使用setTimeout來使onblur時間延期執(zhí)行,使onclick執(zhí)行完后再執(zhí)行onblur。(其中setTimeout的時間設(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='請輸入關(guān)鍵字';

          }

        },120);

      };

    };

  </script>    

</head>

<body>

<form>

  <input type="text" value="請輸入關(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來代替onblur實現(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='請輸入關(guān)鍵字';

        }  

      };

    };

  </script>    

</head>

<body>

<form>

  <input type="text" value="請輸入關(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沖突問題的快速解決方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機網(wǎng)站地址:onclick和onblur沖突問題的快速解決方法

2025國考·省考課程試聽報名

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