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>

これらの 4 つの色付きの div はインラインである必要があります。

4

1 に答える 1

2

display: flex要素で使用できます#containerdisplayが設定されているコンテナ内の要素のデフォルトの方向flexは ですrow。したがって、要素は左から右に移動します。

.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 に答える