js滑鼠滑過彈出層的定位bug解決辦法

來源:互聯網
上載者:User

大家在寫div+css的時候經常會用到彈出層,由於IE6的bug,所以當使用多個標籤重複寫彈出層的時候會遇到後面的層壓在了彈出層的上面,這種問題在Firefox瀏覽器下可以用z-index來解決,但是在IE6下面是不起作用的,下面的代碼給大家提供了一種此類問題的解決辦法,原理如下:用Jquery給彈出層的z軸依次增加高度.代碼很簡單,效果很顯著,吼吼!
 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 <html xmlns="http://www.w3.org/1999/xhtml">
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>彈出層問題的解決辦法</title>
 <style>
 .box { width:800px; margin:10px auto; background:#f1f1f1; z-index:0; padding:10px;display:inline-table; text-align:center;}
 .box ul li { width:150px; height:150px; float:left; border:solid 1px #ccc; background:#CCFF99; margin:10px; position:relative; list-style:none;}
 .box ul li .layer { position:absolute; left:150px; top:0; width:120px; height:100px; background:#000; color:#fff; z-index:99999;}
 
</style>
 <script src="jquery-1.3.2.min.js" type="text/javascript"></script>
 
</head>
 <body>
 <div class="box">
  <ul id="boxcotent">
   <li><a href="#">測試新聞標題一</a>
    <div class="layer" style=" display:none;">
     <a href="#">這裡顯示彈出層</a>
    </div>
   </li>
   <li><a href="#">測試新聞標題一</a>
    <div class="layer" style=" display:none;">
     <a href="#">這裡顯示彈出層</a>
    </div>
   </li>
   <li><a href="#">測試新聞標題一</a>
    <div class="layer" style=" display:none;">
     <a href="#">這裡顯示彈出層</a>
    </div>
   </li>
   <li><a href="#">測試新聞標題一</a>
    <div class="layer" style=" display:none;">
     <a href="#">這裡顯示彈出層</a>
    </div>
   </li>
   <li><a href="#">測試新聞標題一</a>
    <div class="layer" style=" display:none;">
     <a href="#">這裡顯示彈出層</a>
    </div>
   </li>
   <li><a href="#">測試新聞標題一</a>
    <div class="layer" style=" display:none;">
     <a href="#">這裡顯示彈出層</a>
    </div>
   </li>
   <li><a href="#">測試新聞標題一</a>
    <div class="layer" style=" display:none;">
     <a href="#">這裡顯示彈出層</a>
    </div>
   </li>
  </ul>
 </div>
 <script type="text/javascript">
  for(var i = 0; i < $(".box li").length;i++){
   var j = 10000-i
   $(".box li").eq(i).css("z-index",j);
  }
  $("#boxcotent li").hover(function(){
   $(this).children(".layer").show();},function(){$(this).children(".layer").hide();}
   );
   $("#boxcotent li").hover(function(){
   $(this).addClass("s");},function(){$(this).removeClass("s");}
  );
 </script>
 </body>
 </html>
 
以上JS代碼需要引入jquery-1.3.2.min.js檔案
 
關鍵JS代碼
 
 for(var i = 0; i < $(".box li").length;i++){
   var j = 10000-i
   $(".box li").eq(i).css("z-index",j);
  }
 
摘自 採菊東籬下
 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.