创建下拉菜单

时间:2015-02-03 08:42:54

标签: jquery html css menu

大家好我现在正在网站上工作,我想用下拉子菜单创建水平导航菜单。在下面我添加一些网站示例导航菜单。当您点击免费教程时,您将明白我的意思。我可以使用ul和li以及css创建简单的下拉菜单,但我不知道如何为每一行指定不同的悬停颜色。

我希望有人指导我创建这个。链接是;

http://tutsplus.com/

谢谢大家

这是我正在尝试的

在源代码中我写了这个:

<ul>
   <li class='active'><a href='index.html'><span>Main Menu</span></a></li>
   <li class='has-sub'><a href='#'><span>Main Menu 2</span></a>
      <ul>
         <li class='has-sub'><a href='#'><span>Sub Menu </span></a>
            <ul>
               <li><a href='#'><span>Sub Item 1</span></a></li>
               <li class='last'><a href='#'><span>Sub Item 2</span></a></li>
            </ul>
         </li>
         <li class='has-sub'><a href='#'><span>Main Menu 2</span></a>
            <ul>
               <li><a href='#'><span>Sub Item</span></a></li>
               <li class='last'><a href='#'><span>Sub Item</span></a></li>
            </ul>
         </li>
      </ul>
   </li>
   <li><a href='#'><span>Main Menu 3</span></a></li>
   <li class='last'><a href='#'><span>Main Menu 4</span></a></li>
</ul>

和css是

#menu {
  border: none;
  border: 0px;
  margin: 0px;
  padding: 0px;
  font: 67.5% "Lucida Sans Unicode", "Bitstream Vera Sans", "Trebuchet Unicode MS", "Lucida Grande", Verdana, Helvetica, sans-serif;
  font-weight: bold;
  width: auto;
}
#menu ul {
  background: #333333;
  height: 35px;
  list-style: none;
  margin: 0;
  padding: 0;
}
#menu li {
  float: left;
  padding: 0px;
}
#menu li a {
  background: #333333 url("images/seperator.gif") bottom right no-repeat;
  display: block;
  font-weight: normal;
  line-height: 35px;
  margin: 0px;
  padding: 0px 25px;
  text-align: center;
  text-decoration: none;
  font-size: 14px;
}
#menu > ul > li > a {
  color: #cccccc;
}
#menu ul ul a {
  color: #ffffff;
}
#menu li > a:hover,
#menu ul li:hover > a {
  background: #58bce1 url("images/hover.png") bottom center no-repeat;
  color: #ffffff;
  text-decoration: none;
}
#menu li ul {
  background: #333333;
  display: none;
  height: auto;
  padding: 0px;
  margin: 0px;
  border: 0px;
  position: absolute;
  width: 225px;
  z-index: 200;
  /*top:1em;
    /*left:0;*/

}
#menu li:hover ul {
  display: block;
}
#menu li li {
  background: url('images/sub_sep.gif') bottom left no-repeat;
  display: block;
  float: none;
  margin: 0px;
  padding: 0px;
  width: 225px;
}
#menu li:hover li a {
  background: none;
}
#menu li ul a {
  display: block;
  height: 35px;
  font-size: 12px;
  font-style: normal;
  margin: 0px;
  padding: 0px 10px 0px 15px;
  text-align: left;
}
#menu li ul a:hover,
#menu li ul li:hover > a {
  background: #58bce1 url('images/hover_sub.png') center left no-repeat;
  border: 0px;
  color: #ffffff;
  text-decoration: none;
}
#menu p {
  clear: left;
}
#menu ul ul li {
  position: relative;
}
#menu ul ul ul {
  left: -9999px;
  top: 0;
}
#menu ul ul li:hover > ul {
  left: 100%;
}
#menu.align-center > ul > li {
  display: inline-block;
  float: none;
}
#menu.align-center > ul {
  text-align: center;
  font-size: 0;
}
#menu > ul > li {
  position: relative;
}
#menu.align-right > ul > li {
  float: right;
}
#menu.align-right > ul > li:hover > ul {
  right: 0;
  left: auto;
  text-align: right;
}
#menu.align-right ul ul li a {
  text-align: right;
}
#menu.align-right ul ul li:hover > ul {
  left: auto;
  right: 100%;
}

2 个答案:

答案 0 :(得分:0)

所以你想为下拉列表中的每个菜单创建一个hover效果吗?所以,当我将鼠标悬停在第一个上面时,它会变红,第二个会变成蓝色?

以下是如何做到的:

#menu ul ul > li:nth-child(2):hover {
    background: #ff0000;
}

这里2表示第二个元素。所以你可以为每个元素添加它。

这里有一个 WORKING FIDDLE (使用其他选择器,这只是为了演示)

答案 1 :(得分:0)

您实际上在寻找this

这正是你想要做的。

希望能帮到你。