1

我正在开发一个需要并排显示多个 div 的导航栏。但是父 div 没有固定的宽度。只是一些填充物。所以问题是我怎样才能做到这一点?

.nav {
  width: 100%;
  height: 50px;
}

.nav ul {
  width: 100%;
  height: 50px;
}

.nav ul li {
  display: inline;
  list-style-type: none;
  background: gray;
  padding: 10px 30px;
  margin: 0 10px;
  height: 100%;
  position: relative;
}

#container {
  position: absolute;
  left: 0;
  top: 100%;
  background: black;
  padding: 10px;
}

#container .category {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 80px;
}
<div class="nav">
  <ul>
    <li>AB
      <div id="container">
        <div class="category" style="background: #4285f4;"></div>
        <div class="category" style="background: #ea4335;"></div>
        <div class="category" style="background: #fbbc05;"></div>
        <div class="category" style="background: #34a853;"></div>
      </div>
    </li>
    <li>CD</li>
    <li>EF</li>
    <li>GH</li>
  </ul>
</div>

这四个彩色 div 必须是内联的。

4

1 回答 1

2

您可以display: flex#container元素上使用。display设置为 的容器内元素的默认方向flexrow。所以元素从左到右。

.nav {
    width: 100%;
    height: 50px;
}

.nav ul {
    width: 100%;
    height: 50px;
}

.nav ul li {
    display: inline;
    list-style-type: none;
    background: gray;
    padding: 10px 30px;
    margin: 0 10px;
    height: 100%;
    position: relative;
}

#container {
    position: absolute;
    left: 0;
    top: 100%;
    background: black;
    padding: 10px;
    display: none;
}

.nav li:hover > #container {
    display: flex;
}

#container .category {
    position: relative;
    display: inline-block;
    width: 50px;
    height: 80px;
}
<div class="nav">
  <ul>
    <li>AB
      <div id="container">
        <div class="category" style="background: #4285f4;"></div>
        <div class="category" style="background: #ea4335;"></div>
        <div class="category" style="background: #fbbc05;"></div>
        <div class="category" style="background: #34a853;"></div>
      </div>
    </li>
    <li>CD</li>
    <li>EF</li>
    <li>GH</li>
  </ul>
</div>

于 2015-09-12T13:56:48.427 回答