IE6 li:hover兼容问题
IE6 li:hover兼容问题,因为IE6不认li:hover,所以需要一段JS代码来实现这个功能;
网上有很多种,这里我选择其中的一种我觉得最方便的,
JS代码:
<script type=”text/javascript”><!–//–><![CDATA[//><!--
sfHover =function() {
var sfEls = document.getElementById("nav").getElementsByTagName("LI");
for (var i=0; i<sfEls.length; i++) {
sfEls[i].onmouseover=function() {
this.className+=” sfhover”;
}
sfEls[i].onmouseout=function() {
this.className=this.className.replace(new RegExp(” sfhover\\b”), “”);
}
}
}
if (window.attachEvent) window.attachEvent(“onload”, sfHover);
//–><!]]>
</script>
导航结构代码
<ul id=“nav”>
<li><a href=“#”>这是显示的标题1</a>
<ul>
<li><a href=“#”>这是列表中的内容1</a></li>
<li><a href=“#”>这是列表中的内容2</a></li>
<li><a href=“#”>这是列表中的内容3</a></li>
<li><a href=“#”>这是列表中的内容4</a></li>
</ul>
</li>
<li><a href=“#”>这是显示的标题2</a>
<ul>
<li><a href=“#”>这是列表中的内容5</a></li>
<li><a href=“#”>这是列表中的内容6</a></li>
<li><a href=“#”>这是列表中的内容7</a></li>
<li><a href=“#”>这是列表中的内容8</a></li>
</ul>
</li>
</ul>
CSS样式代码
#nav, #nav ul{ /* all lists */
padding: 0;
margin: 0;
list-style: none;
line-height: 1;
}
#nav li{ /* all list items */
float: left;
width: 10em;
}
#nav li ul{ /* second-level lists */
position: absolute;
background: orange;
width: 10em;
left: -999em; /* using left instead of display to hide menus because display: none isn’t read by screen readers 这里用left:-999em的也行,用display:none的也行,看您喜欢用啥 */
}
*+ html #nav li ul{margin: 16px 0 0 -95px;} /* 二级菜单显示位置调整IE7 */
*html #nav li ul{margin: 16px 0 0 -95px;} /* 二级菜单显示位置调整 IE6 */
#nav li:hover ul, #nav li.sfhover ul{
left: auto;/* 如果上面用left的了,那么这就不用改,最多改个数,如果用display:none了,那么这里改成display:block*/
}
>> 预览效果
转自:PHPishard(有删改)
ued简洁大方,不错,学习一下