我遇到了一些问题。我知道我这样做的方式很奇怪,并且可能会导致问题,但我想仅使用 CSS 进行尝试。我现在已经很接近了,但是有一个问题,希望在我放弃之前有人可能有一个想法。
基本上我有一个导航栏,可以在悬停时更改图像。与此不同的是,我希望在悬停时更改两个图像。所以我决定我可以通过将两个图像放入一个更大的图像中并将图像溢出悬停链接之外来做到这一点。
现在,它有点工作,但你可以从左到右越过链接,它会很好地显示悬停,但如果你从右到左这样做,它就不起作用。
这是测试的链接http://www.pclwebdesign.co.uk/fruit
我已经尝试过 z 索引来将链接放在前面,因为它显然不起作用,因为跨度在其中。
CSS
body{
background:#FFF;
}
#wrap{
margin:0 auto;
width:894px;
height:900px;
background:url(../images/background.jpg) no-repeat;
}
#header{
position:relative;
margin:0 auto;
width:625px;
height:92px;
}
#navbar{
position:relative;
display:block;
margin-left:114px;
width:626px;
height:170px;
background:url(../images/navbar2.jpg)
}
ul.cssmenu {
list-style: none; padding-left: 24px; margin-top:-12px;
}
.displace {
position: absolute; left: -5000px;
}
ul.cssmenu li {
float: left;
}
ul.cssmenu li a {
display: block; height: 170px;
}
/** Normal Links*/
ul.cssmenu li.about a {
margin-right:10px; width:86px; height:59px;}
ul.cssmenu li.gallery a { width:120px; height:59px;}
ul.cssmenu li.home a { width:150px; height:59px;}
ul.cssmenu li.contact a { width:120px; height:59px;}
ul.cssmenu li.video a { width:97px; height:59px;}
/** Hidden LED Navbar images*/
ul.cssmenu li.about a .led {
display: none; width:626px; height:170px; margin-left:-24px;}
ul.cssmenu li.gallery a .led {
display: none; width:626px; height:170px; margin-left:-120px;}
ul.cssmenu li.home a .led {
display: none; width:626px; height:170px; margin-left:-240px;}
ul.cssmenu li.contact a .led {
display: none; width:626px; height:170px; margin-left:-390px;}
ul.cssmenu li.video a .led {
display: none; width:626px; height:170px; margin-left:-510px; }
/** Hover Links*/
ul.cssmenu li.about a:hover .led {
display: block; width:626px; height:170px; margin-left:-24px; background:url(../images/navbar2.jpg); background-position: 0px -170px;
}
ul.cssmenu li.gallery a:hover .led {
display: block; width:626px; height:170px; margin-left:-120px; background:url(../images/navbar2.jpg); background-position: 0px -340px;
}
ul.cssmenu li.home a:hover .led {
display: block; width:626px; height:170px; margin-left:-240px; background:url(../images/navbar2.jpg); background-position: 0px -510px;
}
ul.cssmenu li.contact a:hover .led {
display: block; width:626px; height:170px; margin-left:-390px; background:url(../images/navbar2.jpg); background-position: 0px -680px;
}
ul.cssmenu li.video a:hover .led {
display: block; width:626px; height:170px; margin-left:-510px; background:url(../images/navbar2.jpg); background-position: 0px -850px;
}
/** Navigation bar finish */
HTML
<div id="wrap">
<div id="header">
</div>
<div id="navbar">
<ul class="cssmenu">
<li class="about"><a href="about.htm" title="About"><span class="led"></span></a></li>
<li class="gallery"><a href="gallery.htm" title="Gallery"><span class="led"></span></a></li>
<li class="home"><a href="home.htm" title="Home"><span class="led"></span></a></li>
<li class="contact"><a href="contact.htm" title="Contact"><span class="led"></span></a></li>
<li class="video"><a href="video.htm" title="Video"><span class="led"></span></a></li>
</ul>
</div>
</div>