2012-03-07 170 views
2

IE9的z-index问题,我想作出一个iframe在模态窗口弹出嵌入YouTube视频。我已经成功地在Chrome和Firefox中工作,但它在IE中不起作用。 Flash视频似乎覆盖了z-index,即使我已将wmode设置为透明(我也尝试使用相同结果的不透明)。弹出视频的菜单正常工作,但直接位于视频上的具有onclick事件的div无法正常工作。我已经尝试手动设置z-index几乎每个元素,没有任何改变。与嵌入式视频

我已经包含了一个HTML页面来演示这个问题。在Chrome和Firefox上,如果您点击视频,您将收到一条警告消息,显示“已点击”消息,但IE浏览器不会发生这种情况。

<html> 
<head> 
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js" type="text/javascript"></script> 
    <script type='text/javascript'> 
     $(function(){ 
      $("ul.dropdown li").hover(function(){ 
       $(this).addClass("hover"); 
       $('ul:first',this).css('visibility', 'visible'); 
      }, function(){ 
       $(this).removeClass("hover"); 
       $('ul:first',this).css('visibility', 'hidden'); 
      }); 

      $("ul.dropdown li ul li:has(ul)").find("a:first").append(" &raquo; "); 
     }); 
    </script> 
    <style type="text/css"> 
     *         { margin: 0; padding: 0; } 
     body        { font: 14px Helvetica, Sans-Serif; } 
     #page-wrap       { width: 800px; margin: 80px auto; } 
     a         { text-decoration: none; } 
     ul         { list-style: none; } 
     p         { margin: 15px 0; } 

     /* 
      LEVEL ONE 
     */ 
     ul.dropdown       { position: relative; } 
     ul.dropdown li      { font-weight: bold; float: left; zoom: 1; background: #ccc; } 
     ul.dropdown a:hover     { color: #000; } 
     ul.dropdown a:active    { color: #ffa500; } 
     ul.dropdown li a     { display: block; padding: 4px 8px; border-right: 1px solid #333; 
               color: #222; } 
     ul.dropdown li:last-child a   { border-right: none; } /* Doesn't work in IE */ 
     ul.dropdown li.hover, 
     ul.dropdown li:hover    { background: #F3D673; color: black; position: relative; } 
     ul.dropdown li.hover a    { color: black; } 


     /* 
      LEVEL TWO 
     */ 
     ul.dropdown ul      { width: 220px; visibility: hidden; position: absolute; top: 100%; left: 0; } 
     ul.dropdown ul li     { font-weight: normal; background: #f6f6f6; color: #000; 
               border-bottom: 1px solid #ccc; float: none; } 

              /* IE 6 & 7 Needs Inline Block */ 
     ul.dropdown ul li a     { border-right: none; width: 100%; display: inline-block; } 

     /* 
      LEVEL THREE 
     */ 
     ul.dropdown ul ul     { left: 100%; top: 0; } 
     ul.dropdown li:hover > ul   { visibility: visible; } 
    </style> 
    <title>IE Bug</title> 
</head> 
<body> 
<div class="page-wrapper"> 
    <div class="menu"> 
     <ul class="dropdown" style="z-index: 100;"> 
      <li> 
       <a href="#">Menu</a> 
       <ul class="sub_menu"> 
        <li><a href="#">Sub Item 1</a></li> 
        <li><a href="#">Sub Item 2</a></li> 
       </ul> 
      </li> 
     </ul> 
    </div> 
    <br /> 

    <div class="span4" style="background-color: transparent; display: block; margin-bottom: 0px; margin-left: 20px; margin-right: 0px; margin-top: 0px; width: 300px; z-index: 4;"> 
     <div class="column" style="margin-left: 0px; padding-bottom: 0px; padding-left: 0px; padding-right: 0px; padding-top: 0px; position: relative; z-index: 3;"> 
      <div class="embedded-video" style="position: relative; z-index: 3;"> 
       <div class="video-launcher" onclick="alert('clicked');" style="position: absolute; cursor: pointer; width: 100%; height: 100%; z-index: 2;"></div> 
       <div class="youtube-video" style="z-index: 1;"> 
        <iframe style="z-index: 1;" width="300" height="225" src="http://www.youtube.com/embed/W8_Kfjo3VjU?rel=0&showinfo=0&wmode=transparent" frameborder="0" allowfullscreen></iframe> 
       </div> 
      </div> 
     </div> 
    </div> 

</div> 
</body> 

我搜索了所有在试图解决这个问题,但我能找到的关于将wmode设置和Z的索引信息。必须有其他东西,我错过了,或者这可能在IE中不起作用。谢谢您的帮助。

+0

类似的问题在这里:flash对象/ SWF与“的wmode =不透明”在IE8在IE9中工作得很好,现在 - 闪光灯不显示任何文本。如果将wmode更改为“窗口”,则Flash将显示文本,但Flash对象也是最顶层的,并将覆盖其他DOM元素。 – woohoo 2012-03-09 19:49:41

回答

1

你需要的wmode参数的任何页面上的任何位置设置不透明的任何嵌入/ OBJECT标签内不论在何地呈现的 - 在你的网页或你想显示IFRAME。否则,无论哪个页面(iframe或其他)将其展示出来,Flash播放器都将位于所有内容之上(被继承或以其他方式)。它不关心它不在你的页面上。它在浏览器中显示。

如果你显示其他网站的网站上的内容可能会有问题。幸运的是,YouTube有一个解决方案:

在IFRAME中添加?wmode =透明到YouTube网址的末尾(如果您有查询字符串,则为& wmode =透明)。这对于我来说很适合模态。

注:我遇到了这个答案从另一个问题,并将其应用到这一个: https://stackoverflow.com/questions/8278390/how-can-i-make-iframe-respect-z-index-in-ie

+0

其实我正在使用?wmode =透明查询字符串,它仍然有这个问题。如果你看看我的示例页面,你会发现这确实允许玩家之外的菜单重叠玩家,但是与玩家完全相同的DIV不会捕获点击事件。 – Brady 2012-10-12 20:11:43

+0

AWESOMEE​​E !!!!非常感谢! – 2012-10-17 23:00:23

0

唯一我能够使这项工作的方式是让比嵌入的iFrame的DIV较大,所以在鼠标通过iFrame之前,DIV将捕获鼠标悬停。这不是一个完美的解决方案,就好像用户移动鼠标足够快,它不会捕获鼠标悬停。

此问题已在IE10中解决。