如何设置子无序列表位置?

时间:2010-03-14 00:06:20

标签: css

我有一个导航栏,其子项无序列表嵌套在主导航栏项下。我的问题出现在内部列表中,当我定位绝对时,内部列表以页面为中心,当我定位相对时,它与父列表内联定位。

我正在尝试将第一个子项目直接排在其父级之下。

/*  OUTER LIST STYLING  */

div#navbar2 {

    position:relative;
    width: 100%;
    border-top: solid #000 1px;
    border-bottom: solid #546F8B 1px;
    background-color: #546F8B;
}

div#navbar2 ul#navbar {
    padding: 0;
    margin: 10px 0;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 16px;
    letter-spacing:1px;
    color: #FFF;
    white-space: nowrap;

}

div#navbar2 ul#navbar li {
    margin: 0 2px;
    list-style-type: none;
    display: inline;
}


div#navbar2 li a {
   text-decoration: none;
   color: #fff;
   padding: 10px 10px;
}

div#navbar2 li a:link {
    color: #FFF:
}

div#navbar2 li a:visited {
    color: #ffffff;
}

div#navbar2 li a:hover {
    color: #000;
    background-color: #FDFFC9;
}

/*   INNER LIST STYLING   */

div#navbar2 ul#navbar li ul.innerlist{
    display: none; 
    color:#000;

}
div#navbar2 ul#navbar li ul.innerlist li{
    color:#000;
}


div#navbar2 ul#navbar li:hover ul.innerlist {
    position: absolute;
    display: inline;
    left: 0;
    width: 100%;
    margin: 40px 0 0px 0px;
    padding: 0px; 
    color:#000;
    }

div#navbar2 li.innerlist a {
   text-decoration: none;
   color: #000;
    padding: 10px 10px;
}

div#navbar2 li.innerlist a:link {
    color: #000:
}

div#navbar2 li.innerlist a:visited {
    color: #000;
}

div#navbar2 li.innerlist a:hover {

    color: #000;
    background-color: #FDFFC9;
}

我的HTML:

<div id="navbar2">

<ul id="navbar">
  <li id="index"><a href="index.php">About Rattletree</a></li>
  <li id="upcomingshows"><a href="upcomingshows.php">Calendar</a></li>
  <li id="booking"><a href="booking.php">Contact</a>
            <ul class="innerlist">
                <li class="innerlist"><a href="#">Booking</a></li>
                <li class="innerlist"><a href="#">press</a></li>
            </ul>
  </li>
  <li id="instruments"><a href="instruments.php">The Band</a>
            <ul class="innerlist">
                <li class="innerlist"><a href="#">The Instruments</a></li>
                <li class="innerlist"><a href="#">The Players</a></li>
            </ul>
  </li>
  <li id="classes"><a href="classes.php">Sights &amp; Sounds</a>
            <ul class="innerlist">
                <li class="innerlist"><a href="#">Listen</a></li>
                <li class="innerlist"><a href="#">photos</a></li>
                <li class="innerlist"><a href="#">video</a></li>
            </ul>
  </li>
  <li id"classes"><a href="classes.php">Workshops &amp; Classes</a></li>


</ul>
</div>

感谢您的帮助!

2 个答案:

答案 0 :(得分:3)

如果您设置#navbar > li {position: relative;}ul.innerlist {position: absolute; },那么它及其后代li元素将相对于#navbar > li而不是页面定位。

答案 1 :(得分:0)

如果我理解你想要什么,只需将它添加到你的CSS

#navbar .innerlist {
    display: block;
    margin-left: 0px;
    padding-left: 0px;
}