亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

實例講解jquery中mouseleave和mouseout的區(qū)別

 更新時間:2016年02月17日 09:46:24   投稿:lijiao  
這篇文章主要以實例詳細講解了jquery中mouseleave和mouseout的區(qū)別,模仿下拉框效果,感興趣的小伙伴們可以參考一下

本文詳細的介紹了關(guān)于jQuery中mouseleave和mouseout的區(qū)別,分享給大家供大家參考,具體內(nèi)容如下
很多人在使用jQuery實現(xiàn)鼠標(biāo)懸停效果時,一般都會用到mouseover和mouseout這對事件。而在實現(xiàn)過程中,可能會出現(xiàn)一些不理想的狀況。
先看下使用mouseout的效果:

<p>先看下使用mouseout的效果:</p>
<div id="container" style="width: 300px;">
<div id="title" style="cursor: pointer; background: #ccc;">使用了mouseout事件↓</div>
<div id="list" style="display: none; position: absolute; background:#fff; border: 1px solid #ccc; width: 298px;">
<div>第一行</div>
<div>第二行</div>
<div>第三行</div>
</div>
</div>
<p><script type='text/javascript'> 
jQuery(document).ready(function($) { 
   $("#title").mouseover(function() { 
     var offset = $(this).offset(); 
     $("#list").css({left: offset.left, top: offset.top+19}).show(); 
   }); 
   $("#container").mouseout(function() { 
     $("#list").hide(); 
   }); 
 }); 
</script>

第一行第二行第三行我們發(fā)現(xiàn)使用mouseout事件時,鼠標(biāo)只要在下拉容器#list里一移動,就觸發(fā)了hide(),其實是因為mouseout事件是會冒泡的,也就是事件可能被同時綁定到了該容器的子元素上,所以鼠標(biāo)移出每個子元素時也都會觸發(fā)我們的hide()。
從jQuery 1.3開始新增了2個mouse事件,mouseenter和mouseleave。與mouseout事件不同,只有在鼠標(biāo)指針離開被選元素時,才會觸發(fā) mouseleave 事件。
我們來看一下mouseleave事件的效果:

<div id="container2" style="width: 300px;">
<div id="title2" style="cursor: pointer; background: #ccc;">使用了mouseleave事件↓</div>
<div id="list2" style="display: none; position: absolute; background:#fff; border: 1px solid #ccc; width: 298px;">
<div>第一行</div>
<div>第二行</div>
<div>第三行</div>
</div>
</div>
<script type='text/javascript'> 
jQuery(document).ready(function($) { 
   $("#title2").mouseover(function() { 
     var offset = $(this).offset(); 
     $("#list2").css({left: offset.left, top: offset.top+19}).show(); 
   }); 
   // 綁定mouseleave事件,效果很好 
   $("#container2").mouseleave(function() { 
     $("#list2").hide(); 
   }); 
 }); 
</script>
<p>

第一行第二行第三行mouseleave和mouseout事件各有用途,因為事件冒泡在某些時候是非常有用的
解決div mouseout事件冒泡的問題
解決的辦法是,使用jquery的bind方法
 如:現(xiàn)在有一個div對象需要監(jiān)聽他的鼠標(biāo)事件

<div class="dpx2"><div class="dpx2_px" style="cursor:pointer;" id="searchSort">請選擇排序方式↓</div>
      <div class="dpx2_px_xl" id="sortList" style="display:none;position:absolute;z-index:5;">
        <div><a class="sortA">按時間升序↑</a></div>
        <div><a class="sortA">按時間降序↓</a></div>
        <div><a class="sortA">按評論數(shù)量升序↑</a></div>
        <div><a class="sortA">按評論數(shù)量降序↓</a></div>
        <div><a class="sortA">按點擊數(shù)升序↑</a></div>
        <div><a class="sortA">按點擊數(shù)降序↓</a></div>
      </div>
    </div>

當(dāng)鼠標(biāo)移動到ID為searchSort的Div上時,顯示下面的div。當(dāng)鼠標(biāo)移出下面的div時,隱藏div
JS為:

 $(function(){
         var sortList = $("#sortList");
      $("#searchSort").mouseover(function() {
         var offset = $(this).offset();
        sortList.css("left", offset.left);
        sortList.css("top", offset.top+20);
        sortList.show();
      });
//關(guān)鍵的一句,綁定Div對象的mouseleave事件
      sortList.bind("mouseleave", function() {
        $(this).hide();
      });
    });

根據(jù)上述講解,模擬實現(xiàn)下拉效果: 
1.不論鼠標(biāo)指針離開被選元素還是任何子元素,都會觸發(fā) mouseout 事件。

2.只有在鼠標(biāo)指針離開被選元素時,才會觸發(fā) mouseleave 事件。

<div class="sel_box">
  <input type="button" value="請選擇所屬部門" id="sel_dept" />
  <div class="hide" id="sel_dept_sh" style="display: none;">
    <p>
      <font>深圳市公司 </font>
    </p>
    <p>
      <font>集團管理層 </font>
    </p>
  </div>
</div>
 
<script type="text/javascript">
$(".sel_box").click(function(event){
   if(event.target.id == 'sel_dept'){
     $("#sel_dept_sh").show(); //顯示下拉框
     $("#sel_dept_sh p font").click(function(){
       $("#sel_dept").val('');
       var text = $(this).text();
      // alert(text);
       $("#sel_dept").val(text).css("color","#000");
       $("#sel_dept_sh").hide();
     });
 
   }else{
     $("#sel_dept_sh").hide();
   }
   
 
});
 
$(".sel_box").bind("mouseleave",function(){//用mouseleave就實現(xiàn)了模仿下拉框的效果
    $(this).find(".hide").hide();  
  });
 
$(".sel_box").bind("mouseout",function(){//而mouseout則不行,什么時候都會觸發(fā)
    $(this).find(".hide").hide();  
  });
</script>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。

相關(guān)文章

最新評論