【问题标题】:Create Drop Down Menu创建下拉菜单
【发布时间】:2015-02-03 08:42:54
【问题描述】:

大家好,我现在在网站上工作,我想创建带有下拉子菜单的水平导航菜单。在下面我添加了一些网站示例导航菜单。当您单击免费教程时,您会明白我的意思。我可以使用 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%;
}

【问题讨论】:

  • 你尝试了哪些代码来达到你想要的效果?表明你已经做出了一些努力
  • 也许发布您创建的列表。
  • 我会添加我的,请稍等
  • 我添加了我的作品希望你现在可以帮助我

标签: jquery html css menu


【解决方案1】:

你实际上是在寻找this

这正是你想要做的。

希望能帮到你。

【讨论】:

  • 非常感谢
  • @KemalEkren 欢迎您,如果您想知道它是如何一步一步创建的,请参阅this
【解决方案2】:

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

您可以这样做:

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

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

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

【讨论】:

  • 我创建了悬停效果,但我还需要使所有子菜单的子菜单的宽度和高度相同,并为它们分配不同的颜色
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2018-03-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-09-03
相关资源
最近更新 更多