html - CSS 下拉菜单 - 下拉菜单和子菜单之间的间隙,在 IE 中消失

标签 html css internet-explorer

我目前在 PHP include 上使用 CSS 菜单。我必须与 IE 和 Chrome 兼容,我假设是 Firefox。但是在 IE 中,我的下拉菜单的子菜单离下拉菜单很远,在我悬停在它上面之前就消失了。

原始 CSS

#cssmenu ul { margin: 0; padding: 0;}
#cssmenu li { margin: 0; padding: 0;}
#cssmenu a { margin: 0; padding: 0;}
#cssmenu ul {list-style: none;}
#cssmenu a {text-decoration: none;}
#cssmenu {height: 70px; background-color: rgb(35,35,35); box-shadow: 0px 2px 3px rgba(0,0,0,.4);}


#cssmenu > ul > li {
    float: left;
    margin-left: 15px;
    position: relative;
}

#cssmenu > ul > li > a {
    color: rgb(160,160,160);
    font-family: Verdana, 'Lucida Grande';
    font-size: 15px;
    line-height: 70px;
    padding: 15px 20px;
-webkit-transition: color .15s;
   -moz-transition: color .15s;
     -o-transition: color .15s;
        transition: color .15s;
}

#cssmenu > ul > li > a:hover {color: rgb(250,250,250); }


#cssmenu > ul > li > ul {
    opacity: 0;
    visibility: hidden;
    padding: 16px 0 20px 0;
    background-color: rgb(250,250,250);
    text-align: left;
    position: absolute;
    top: 55px;
    left: 50%;
    margin-left: -90px;
    width: 180px;
-webkit-transition: all .3s .1s;
   -moz-transition: all .3s .1s;
     -o-transition: all .3s .1s;
        transition: all .3s .1s;
-webkit-border-radius: 5px;
   -moz-border-radius: 5px;
        border-radius: 5px;
-webkit-box-shadow: 0px 1px 3px rgba(0,0,0,.4);
   -moz-box-shadow: 0px 1px 3px rgba(0,0,0,.4);
        box-shadow: 0px 1px 3px rgba(0,0,0,.4);
}

#cssmenu > ul > li:hover > ul {
    opacity: 1;
    top: 65px;
    visibility: visible;
}

#cssmenu > ul > li > ul:before{
    content: '';
    display: block;
    border-color: transparent transparent rgb(250,250,250) transparent;
    border-style: solid;
    border-width: 10px;
    position: absolute;
    top: -20px;
    left: 50%;
    margin-left: -10px;
}

#cssmenu > ul ul > li { position: relative;}

#cssmenu ul ul a{
    color: rgb(50,50,50);
    font-family: Verdana, 'Lucida Grande';
    font-size: 13px;
    background-color: rgb(250,250,250);
    padding: 5px 8px 7px 16px;
    display: block;
-webkit-transition: background-color .1s;
   -moz-transition: background-color .1s;
     -o-transition: background-color .1s;
        transition: background-color .1s;
}

#cssmenu ul ul a:hover {background-color: rgb(240,240,240);}


#cssmenu ul ul ul {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    top: -16px;
    left: 206px;
    padding: 16px 0 20px 0;
    background-color: rgb(250,250,250);
    text-align: left;
    width: 160px;
-webkit-transition: all .3s;
   -moz-transition: all .3s;
     -o-transition: all .3s;
        transition: all .3s;
-webkit-border-radius: 5px;
   -moz-border-radius: 5px;
        border-radius: 5px;
-webkit-box-shadow: 0px 1px 3px rgba(0,0,0,.4);
   -moz-box-shadow: 0px 1px 3px rgba(0,0,0,.4);
        box-shadow: 0px 1px 3px rgba(0,0,0,.4);
}


#cssmenu ul ul > li:hover > ul { opacity: 1; left: 196px; visibility: visible;}


#cssmenu ul ul a:hover{
    background-color: rgb(205,44,36);
    color: rgb(240,240,240);
}

菜单代码:

<div id='cssmenu'>
<ul>
   <li><a href='index.php'><span>Home</span></a></li>
   <li><a href='about.php'><span>About</span></a></li>
   <li class='has-sub '><a href='#'><span>Services</span></a>
      <ul>
         <li class='has-sub '><a href='4wdtraining.php'><span>4WD Training</span></a>
            <ul>
               <li><a href='basictraining.php'><span>Basic</span></a></li>
               <li><a href='intermediatetraining.php'><span>Intermediate</span></a></li>
               <li><a href='advancedtraining.php'><span>Advanced</span></a></li>
               <li><a href='nightdriving.php'><span>Night Driving</span></a></li>
               <li><a href='recovery.php'><span>Recovery</span></a></li>
               <li><a href='custompackages.php'><span>Custom Packages</span></a></li>
            </ul>
         </li>
         <li><a href='bushmechanic.php'><span>Bush Mechanic</span></a></li>
      </ul>
   </li>
   <li><a href='estore.php'><span>eStore</span></a></li>
   <li><a href='gallery.php'><span>Gallery</span></a></li>
   <li><a href='#'><span>Contact</span></a></li>
</ul>
</div>

www.offthebitumen.com.au 上的实例 我尝试过的事情:更改填充,将位置从绝对位置更改为相对位置,去除边框,添加显示:内联 - 没有任何效果。

另外,如果有人有 Chrome 和 IE,为什么菜单比 IE 版本更圆?有什么我可以做的吗?

最佳答案

那是因为你有差距。

我做了一些小技巧,希望它能有所帮助。

<div id='cssmenu'>
<ul>
   <li><a href='index.php'><span>Home</span></a></li>
   <li><a href='about.php'><span>About</span></a></li>
   <li class='has-sub '><a href='#'><span>Services</span></a>
      <ul>
         <li class='has-sub '><a href='4wdtraining.php'><span>4WD Training</span></a>
            <ul>
               <li><a href='basictraining.php'><span>Basic</span></a></li>
               <li><a href='intermediatetraining.php'><span>Intermediate</span></a></li>
               <li><a href='advancedtraining.php'><span>Advanced</span></a></li>
               <li><a href='nightdriving.php'><span>Night Driving</span></a></li>
               <li><a href='recovery.php'><span>Recovery</span></a></li>
               <li><a href='custompackages.php'><span>Custom Packages</span></a></li>
            </ul>
            <!-- THIS IS THE FIX --> <div class="hack"></div> <!-- end FIX -->
         </li>
         <li><a href='bushmechanic.php'><span>Bush Mechanic</span></a></li>
      </ul>
   </li>
   <li><a href='estore.php'><span>eStore</span></a></li>
   <li><a href='gallery.php'><span>Gallery</span></a></li>
   <li><a href='#'><span>Contact</span></a></li>
</ul>
</div>

只有 2 位的 css:

#cssmenu ul ul > li:hover > ul { opacity: 1; left: 196px; visibility: visible;}
#cssmenu ul ul ul {
   z-index: 5;
}

祝你好运!

关于html - CSS 下拉菜单 - 下拉菜单和子菜单之间的间隙,在 IE 中消失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11596915/

相关文章:

javascript - 如何在php ajax中限制字符并显示剩余字符

javascript - 以编程方式将输入置于编辑状态(就像用鼠标点击它一样)

css - IE8 中行内 block 元素之间不需要的空间,似乎与父级高度相关

html - 所有浏览器中边缘都有空格,HTML?

internet-explorer - IE 无法下载带有 unicode 路径名的 bmp 文件

javascript - 单击按钮时防止 onDocumentMouseDown?

javascript - 给标题下划线css动画

css - 设置Highcharts饼图的不透明度

css - 带有下拉菜单的选项卡在现代浏览器中悬停时不会保持高度

javascript - Videojs 无法在 IE 9 及更高版本中工作