简体   繁体   English

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

[英]Make Sub menu and Sub-Sub menu of same height

I have a drop-down menu with 3 Levels. 我有一个包含3个级别的下拉菜单。 What I am trying to achieve is to make the same height of SubMenu and Sub-SubMenu. 我想要实现的是使SubMenu和Sub-SubMenu具有相同的高度。 Both of the menus should have the same height irrespective of items in each column(Sub Menu and Sub-Sub Menu). 无论每列(子菜单和子子菜单)中的项目如何,两个菜单都应具有相同的高度。

Here is the HTML and CSS code which I'm using. 这是我正在使用的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> 

Here is the example screenshot which I want to achieve. 这是我想要实现的示例屏幕截图。 在此输入图像描述

Thanks in advance. 提前致谢。

To try to resolve your problem, I used jquery 'cause I could not think a pure CSS solution. 为了解决你的问题,我使用了jquery,因为我无法想到纯CSS解决方案。 So this is only a possible way. 所以这只是一种可能的方式。

In my solution, for every 1st level <li> I created a loop to get the tallest <ul> in it and I put the result as height of every <ul> in that <li> . 在我的解决方案中,对于每个第一级<li>我创建了一个循环以获得最高的<ul> ,并将结果作为<li>中每个<ul>高度。

This is the script (see also this: Use jQuery/CSS to find the tallest of all elements ): 这是脚本(另请参见: 使用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);
});

In your CSS, I used visibility:visible & hidden to get the <ul> height (removing your display:none & block ). 在你的CSS中,我使用了visibility:visible & hidden来获取<ul>高度(删除你的display:none & block )。

This is all code in action. 这是所有代码的实际操作。 Hope it helps. 希望能帮助到你。 :) :)

 $("#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> 

Its the best if you restructure your html. 如果你重构你的HTML,它是最好的。

.dropdown class was added to make easier to target. 添加.dropdown类以使目标更容易。

Is this what you wanted? 这是你想要的吗?

https://jsfiddle.net/q1m0kany/2/ 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;
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM