制作相同高度的子菜单和子子菜单

4
我有一个有3个级别的下拉菜单。 我想实现的目标是使子菜单和子子菜单的高度相同。 无论每列中有多少项(子菜单和子子菜单),两个菜单都应该具有相同的高度。
以下是我正在使用的HTML和CSS代码。

html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

* {
  margin: 0px;
  padding: 0px;
}

#main {
  max-width: 1000px;
  margin: 0 auto;
}

#menu:after {
  content: "";
  clear: both;
  display: block;
}

#menu {
  background-color: #000;
}

#menu ul {
  list-style: none;
  position: relative;
  float: left;
  margin: 0;
  padding: 0
}

#menu ul a {
  display: block;
  color: #231F20;
  font-size: 12px;
}

#menu ul li {
  float: left;
  margin: 0;
  padding: 0
}

#menu ul li.current {
  background: #ddd
}

#menu ul ul {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background: #fff;
  border: 1px solid #4598cc;
  padding: 20px 0px;
  z-index: 5;
}

#menu ul ul li {
  float: none;
  width: 200px;
  padding: 5px 10px;
}

#menu ul ul a {
  color: #4598cc;
  display: block;
  padding: 5px 0;
  font-style: 14px;
  font-family: FFMarkStdBook;
}

#menu ul ul ul {
  top: 0;
  left: 100%;
  height: 100%;
}

#menu ul li:hover>ul {
  display: block
}

#menu>ul>li {
  float: left;
  margin-right: 47px;
  position: relative;
}

#menu>ul>li:last-child {
  margin-right: 0px;
}

#menu>ul>li>a {
  color: #fff;
  text-transform: uppercase;
  font-size: 14px;
  padding: 10px;
  text-decoration: none;
}

#menu>ul>li>ul b {
  color: #4598cc;
  font-size: 14px;
  text-transform: uppercase;
  font-weight: normal;
}
<div id="main">
  <nav id="menu">
    <ul>
      <li><a href="#">Home</a></li>
      <li><a href="#">Services</a>
        <ul>
          <li><a href="#">Link One ></a>
            <ul>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
          <li><a href="#">Link One ></a>
            <ul>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
          <li><a href="#">Link One ></a>
            <ul>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
        </ul>
      </li>
      <li><a href="#">Projects</a>
        <ul>
          <li><a href="#"> Link One</a>
            <ul>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
          <li><a href="#"> Link One</a></li>
          <li><a href="#"> Link One</a></li>
        </ul>
      </li>
      <li><a href="#">Blog</a></li>
      <li><a href="#">Contact</a></li>
    </ul>
  </nav>
</div>

以下是我想要实现的示例截图。 在这里输入图片描述

提前致谢。


你有在 jsFiddle 上的示例吗? - tonoslfx
嗨@tonoslfx 这是链接https://jsfiddle.net/Codechk/q1m0kany/. - Codechk
2个回答

2
为了解决您的问题,我使用了jQuery,因为我无法想到一个纯CSS的解决方案。所以这只是一种可能的方法。
在我的解决方案中,对于每个第一级的<li>,我创建了一个循环来获取其中最高的<ul>,并将结果作为该<li>中每个<ul>的高度。
以下是脚本(请参见此处:使用jQuery/CSS查找所有元素中最高的元素):
$("#menu > ul > li").each(function(){
  var maxHeight = 0;
  var myUl=$("ul", $(this));

  myUl.each(function(){
    maxHeight = maxHeight > $(this).height() ? maxHeight : $(this).height();
  });

  myUl.height(maxHeight);
});

在你的CSS样式中,我使用了visibility:visible & hidden来获取<ul>元素的高度(替代了原先的display:none & block)。

这是完整的代码实现。希望对你有所帮助。:)

$("#menu > ul > li").each(function(){
  var maxHeight = 0;
  var myUl=$("ul", $(this));
  
  myUl.each(function(){
    maxHeight = maxHeight > $(this).height() ? maxHeight : $(this).height();
  });

  myUl.height(maxHeight);
});
html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

* {
  margin: 0px;
  padding: 0px;
}

#main {
  max-width: 1000px;
  margin: 0 auto;
}

#menu:after {
  content: "";
  clear: both;
  display: block;
}

#menu {
  background-color: #000;
}

#menu ul {
  list-style: none;
  position: relative;
  float: left;
  margin: 0;
  padding: 0
}

#menu ul a {
  display: block;
  color: #231F20;
  font-size: 12px;
}

#menu ul li {
  float: left;
  margin: 0;
  padding: 0
}

#menu ul li.current {
  background: #ddd
}

#menu ul ul {
  position: absolute;
  top: 100%;
  left: 0;
  background: #ffffff;
  border: 1px solid #4598cc;
  padding: 20px 0px;
  z-index: 5;
  display:block;
  visibility:hidden;
}

#menu ul ul li {
  float: none;
  width: 200px;
  padding: 5px 10px;
}

#menu ul ul a {
  color: #4598cc;
  display: block;
  padding: 5px 0;
  font-style: 14px;
  font-family: FFMarkStdBook;
}

#menu ul ul ul {
  top: -1px;
  left: 100%;
  height: auto;
}

#menu ul li:hover>ul {
  visibility:visible;
}

#menu>ul>li {
  float: left;
  margin-right: 47px;
  position: relative;
}

#menu>ul>li:last-child {
  margin-right: 0px;
}

#menu>ul>li>a {
  color: #fff;
  text-transform: uppercase;
  font-size: 14px;
  padding: 10px;
  text-decoration: none;
}

#menu>ul>li>ul b {
  color: #4598cc;
  font-size: 14px;
  text-transform: uppercase;
  font-weight: normal;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="main">
  <nav id="menu">
    <ul>
      <li><a href="#">Home</a></li>
      <li><a href="#">Services</a>
        <ul>
          <li><a href="#">Link One ></a>
            <ul>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
          <li><a href="#">Link One ></a>
            <ul>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
          <li><a href="#">Link One ></a>
            <ul>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
        </ul>
      </li>
      <li><a href="#">Projects</a>
        <ul>
          <li><a href="#"> Link One</a>
            <ul>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
          <li><a href="#"> Link One</a></li>
          <li><a href="#"> Link One</a></li>
        </ul>
      </li>
      <li><a href="#">Blog</a></li>
      <li><a href="#">Contact</a></li>
    </ul>
  </nav>
</div>


1
非常感谢您的帮助。我真的很感激您的努力,这正是我所寻找的。再次感谢,伙计 :) - Codechk

0

如果您重构HTML,效果会更好。

添加了.dropdown类以便更容易地进行定位。

这是您想要的吗?

https://jsfiddle.net/q1m0kany/2/

<div id="main">
  <nav id="menu">
    <ul>
      <li><a href="#">Home</a></li>
      <li><a href="#">Services</a>
        <ul class="dropdown">
          <li><a href="#">Link One ></a>
            <ul class="dropdown">
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
          <li><a href="#">Link One ></a>
            <ul class="dropdown">
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
          <li><a href="#">Link One ></a>
            <ul class="dropdown">
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
        </ul>
      </li>
      <li><a href="#">Projects</a>
        <ul class="dropdown">
          <li><a href="#"> Link One</a>
            <ul class="dropdown">
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
              <li><a href="#">Child Link One</a></li>
            </ul>
          </li>
          <li><a href="#"> Link One</a></li>
          <li><a href="#"> Link One</a></li>
        </ul>
      </li>
      <li><a href="#">Blog</a></li>
      <li><a href="#">Contact</a></li>
    </ul>
  </nav>
</div>


html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

* {
  margin: 0px;
  padding: 0px;
}

#main {
  max-width: 1000px;
  margin: 0 auto;
}

#menu:after {
  content: "";
  clear: both;
  display: block;
}

#menu {
  background-color: #000;
}

#menu ul {
  list-style: none;
  position: relative;
  margin: 0;
  padding: 0
}

#menu ul a {
  display: block;
  font-size: 12px;
  text-decoration: none;
}

#menu ul li {
  margin: 0;
  padding: 0;
  display: block;
}


#menu .dropdown {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 5;
}

#menu .dropdown li {
  width: 200px;
  display: block;
  background-color: gray;
  border-bottom: 1px solid black;
}

#menu .dropdown > li > a {
  font-style: 14px;
  padding: 5px;
  color: white;
  font-family: FFMarkStdBook;
}

#menu .dropdown .dropdown {
  top: 0;
  left: 100%;
  height: 100%;
}

#menu ul li:hover > .dropdown {
  display: block
}

#menu>ul>li {
  float: left;
  margin-right: 47px;
  position: relative;
}

#menu>ul>li:last-child {
  margin-right: 0px;
}

#menu>ul>li>a {
  color: #fff;
  text-transform: uppercase;
  font-size: 14px;
  padding: 10px;
  text-decoration: none;
}

#menu>ul>li>ul b {
  color: #4598cc;
  font-size: 14px;
  text-transform: uppercase;
  font-weight: normal;
}

请查看用户2922985的屏幕截图! - Coli
感谢您的帮助@tonoslfx,但这并不是我真正想要实现的,请参考截图以获得更多澄清。我想使子菜单和子子菜单持有者具有相同的高度和边框,而不考虑项目。看起来需要一些jQuery来在运行时管理高度。 - Codechk

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接