0

我创建了一个带有一些 Jquery 效果的菜单,它在除 Firefox 之外的所有浏览器上运行良好(我的最后一个菜单项没有居中),我不知道为什么会发生这种情况......它在 Firefox 中看起来像这样:http:/ /robertpeic.com/future%20net/problem/problem.png                          在其他浏览器中呈现良好:http

://robertpeic.com/future%20net/problem/other.png为了解决这个问题,我尝试过:添加固定宽度和高度到我的最后一个锚标签(失败),尝试添加边距而不是填充(失败),尝试通过 CSS 使用 Firefox hack,但它破坏了我的 CSS 验证(失败),尝试增加一点填充,看起来不错Firefox,但在所有其他浏览器中都中断了(失败)。

我最后的手段是使用浏览器嗅探,但我真的不想在这么小的问题上使用它。
有人可以帮我解决这个问题吗?

小提琴示例在这里

CSS 代码:

.menu{
position:relative;
display:block;
margin:0px auto;
height:37px;
background:url(http://robertpeic.com/future%20net/template%20images/menu-bg.png);
width:959px;

}


.menu ul{
list-style-type:none;
display:block;
width:990px;
margin:0 auto;
}

.menu ul li a{
float:left;
color:#4e4e4e;
font-family:"Palatino Linotype", "Book Antiqua", Palatino, serif;
display:table-cell;
position:relative;
height:37px;
text-decoration:none;
background:url(http://robertpeic.com/future%20net/template%20images/main-menu-divider.png) 100% 0%;
background-repeat:no-repeat;
z-index:100;
padding:0px 18px 0px 18px;
line-height:37px;
text-align:left;
margin-left:2px;
}

.menu ul li a:hover{
float:left;
color:#780C71;
font-family:"Palatino Linotype", "Book Antiqua", Palatino, serif;
display:table-cell;
position:relative;
height:37px;
text-decoration:none;
background:url(http://robertpeic.com/future%20net/template%20images/main-menu-divider.png) 100% 0%;
background-repeat:no-repeat;
z-index:100;
padding:0px 18px 0px 18px;
line-height:38px;
text-align:center;
margin-left:2px;
}

.mainhover{
background-color:#BFC0C1;
z-index:50;
position:absolute;
border-radius:5px;
moz-border-radius:5px;
border-top: 1px solid #A09F9F;
border-left: 1px solid #B5B3B3;
border-right: 1px solid #EFEFEF;
border-bottom: 1px solid #EDEDED;
}

.remove{
background-color:#C4C3C2;
z-index:50;
position:absolute;
border-radius:5px;
moz-border-radius:5px;
border-top: 1px solid #A09F9F;
border-left: 1px solid #B5B3B3;
border-right: 1px solid #EFEFEF;
border-bottom: 1px solid #EDEDED;
}

.menu ul li a.contact{
background-image:none;
padding:0px 30px 0px 23px;
text-align:center;
margin-left:6px;
}

jQuery代码:

      $(document).ready(function(){
      var manageWidth = 14;
      var manageHeight = 10;
      var manageMargin = 6;

  $('.menu ul li a').hover(function(){

  var getHeight = $(this).outerHeight(true);
  var getWidth = $(this).outerWidth(true);
  $('<span class="mainhover" />').insertAfter($(this));
  $('.menu ul li .mainhover').css({'width':getWidth-manageWidth,'height':getHeight-manageHeight,'margin-top':'4px','margin-left':-getWidth+manageMargin ,'opacity':'0'});
  $('.menu ul li .mainhover').stop().animate({opacity:1},700);
  //alert(getWidth);
  },function(){
  $('.menu ul li a').next().removeClass('mainhover').addClass('remove').stop().animate({opacity:0},700,function(){
  $(this).remove();
});

});

    });
4

2 回答 2

1

我建议你不要使用 span,使用 div 元素来修复它。或者你可以尝试添加'text-align:center;' 给父母,'text-align:left'给孩子。祝你好运

于 2012-10-29T13:43:14.973 回答
0

我认为问题是因为 .menu ul 的宽度为 990px​​,只需使用 100%;

于 2012-10-29T13:46:30.360 回答