2009-12-10 75 views
1

討厭甚至問什麼毫無疑問是一個非常簡單的問題,但我不明白什麼是錯的。jquery導航,css定位

試圖讓我的子導航飛出「向上」而不是「向下」。向下工作完美。我嘗試添加左側和底部的值,並且可以在Dreamweaver我的導航欄看起來正確的,但是當我運行它,它一切都錯了

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>Untitled Document</title> 
<style type="text/css"> 
<!-- 

body, td, th { 
    font-family: Arial, Helvetica, sans-serif; 
    font-size:12px; 
} 

#navBar { 
    margin: 0; 
    padding: 0; 
    overflow:auto; 
    position:relative; 
} 

#navBar li { 
    float: left; 
    list-style: none; 
    font-weight:bold; 
    background: none; 
    text-align:left; 
    width:90px; 
    margin-right:36px; 
    position:relative;  // I guess I need this 
} 

#navBar li.last { margin-right:0px } 

#navBar li a { 
    display: block; 
    padding: 5px; 
    text-decoration: none; 
    border:none; 
    border-bottom: 2px solid #d4d4d4; 
    color: #575757; 
    white-space: nowrap; 
} 

#navBar li a:hover { 
    border-bottom: 2px solid #ee2c23; 
    color: #ee2c23; 
} 

#navBar li ul { 
    margin: 0; 
    padding: 0; 
    position: absolute;  /* I added this */ 
    left: 0;     /* and this */ 
    bottom: 0px;    /* and this */ 
    visibility: hidden; 
    border-top: 1px solid white; 
    background:black; 
    width:120px; 
    filter: alpha(opacity=80); 
    opacity: 0.8; 

} 

#navBar li ul li { 
    float: none; 
    display: inline; 
    text-align:left; 
    border:none; 
    background: #000; 
} 

#navBar li ul li a { 
    width: auto; 
    border:none; 
    color: #fff; 
} 

#navBar li ul li a:hover { 
    width: auto; 
    border:none; 
    text-decoration:underline; 
    color: #fff; 
} 

#nav { 
    width:753px; 
    background: #fff; 
    margin-top:1px; 
} 
--> 
</style> 
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js" type="text/javascript"></script> 
<script type="text/javascript"> 
var timeout = 500; 
var closetimer = 0; 
var ddmenuitem = 0; 

function navBar_open() 
{ navBar_canceltimer(); 
    navBar_close(); 
    ddmenuitem = $(this).find('ul').css('visibility', 'visible');} 

function navBar_close() 
{ if(ddmenuitem) ddmenuitem.css('visibility', 'hidden');} 

function navBar_timer() 
{ closetimer = window.setTimeout(navBar_close, timeout);} 

function navBar_canceltimer() 
{ if(closetimer) 
    { window.clearTimeout(closetimer); 
     closetimer = null;}} 

$(document).ready(function() 
{ $('#navBar > li').bind('mouseover', navBar_open) 
    $('#navBar > li').bind('mouseout', navBar_timer)}); 

document.onclick = navBar_close; 
</script> 
</head> 
<body> 
<br /><br /><br /><br /><br /> <!-- some padding to see where the menu *should* go --> 
<div id="nav"> 
    <ul id="navBar"> 
    <li><a href="#">Link</a></li> 
    <li><a href="#">Link</a> <!-- when you hover, this should appear above this li --> 
     <ul> 
     <li><a href="#">Link</a></li> 
     <li><a href="#">Link</a></li> 
     <li><a href="#">Link</a></li> 
     <li><a href="#">Link</a></li> 
     </ul> 
    </li> 
    <li><a href="#">Link</a></li> 
    </ul> 
</div> 
</body> 
</html> 

我會發佈一個鏈接,但以不開發服務器的訪問時刻。

如果您刪除了我已評論的這幾行,此作品罰款對於「下拉式」菜單..但我想要一個「drop-up」菜單。

謝謝!

回答

1

爲什麼不使用已經制作好的菜單?

CSS Play有一個巨大的選擇...

等等


編輯:我發現在CSS問題...在#navBar定義,刪除overflow: auto,它會阻止子

#navBar { 
    margin: 0; 
    padding: 0; 
    position:relative; 
} 

的顯示,並從0改變底部像2em

#navBar li ul { 
margin: 0; 
padding: 0; 
position: absolute; 
left: 0; 
bottom: 2em; 
visibility: hidden; 
border-top: 1px solid white; 
background:black; 
width:120px; 
filter: alpha(opacity=80); 
opacity: 0.8; 
} 
0

假設一個絕對定位的對象,您將其底部設置爲元素的位置()。

$("#menuitem").hover(function() { 
    $("#submenu").css({"position" : "absolute", "bottom" : $(this).position().top, "left" : $(this).position().left }); 
});