【问题标题】:How to align Hamburger menu items?如何对齐汉堡菜单项?
【发布时间】:2021-03-16 22:31:39
【问题描述】:

我在导航栏中有某些菜单项。它在移动视图中呈现时转换为汉堡包,因此具有响应性。汉堡菜单中的项目未正确对齐。以下是代码参考

body {
  margin: 0;
  font-family: Helvetica, sans-serif;
  background-color: #f4f4f4;
}

a {
  color: #000;
}

.header {
  background-color: #fff;
  box-shadow: 1px 1px 4px 0 rgba(0, 0, 0, 0.1);
  position: fixed;
  width: 100%;
  z-index: 3;
}

.header ul {
  margin: 0;
  padding: 0;
  list-style: none;
  overflow: hidden;
  background-color: #fff;
}

.header li a {
  display: block;
  padding: 20px 20px;
  border-right: 1px solid #f4f4f4;
  text-decoration: none;
}

.header li a:hover,
.header .menu-btn:hover {
  background-color: #f4f4f4;
}

.header .logo {
  display: block;
  float: left;
  font-size: 2em;
  padding: 10px 20px;
  text-decoration: none;
}

.header .menu {
  clear: both;
  max-height: 0;
  transition: max-height 0.2s ease-out;
}

.header .menu-icon {
  cursor: pointer;
  display: inline-block;
  float: right;
  padding: 28px 20px;
  position: relative;
  user-select: none;
}

.header .menu-icon .navicon {
  background: #333;
  display: block;
  height: 2px;
  position: relative;
  transition: background 0.2s ease-out;
  width: 18px;
}

.header .menu-icon .navicon:before,
.header .menu-icon .navicon:after {
  background: #333;
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  transition: all 0.2s ease-out;
  width: 100%;
}

.header .menu-icon .navicon:before {
  top: 5px;
}

.header .menu-icon .navicon:after {
  top: -5px;
}

.header .menu-btn {
  display: none;
}

.header .menu-btn:checked~.menu {
  max-height: 240px;
}

.header .menu-btn:checked~.menu-icon .navicon {
  background: transparent;
}

.header .menu-btn:checked~.menu-icon .navicon:before {
  transform: rotate(-45deg);
}

.header .menu-btn:checked~.menu-icon .navicon:after {
  transform: rotate(45deg);
}

.header .menu-btn:checked~.menu-icon:not(.steps) .navicon:before,
.header .menu-btn:checked~.menu-icon:not(.steps) .navicon:after {
  top: 0;
}

.menu-search {
  display: flex;
  flex-wrap: wrap;
  float: right;
}

.search-box h5 {
  color: red;
}


/* 48em = 768px */

@media (min-width: 52em) {
  .header li {
    float: left;
  }
  .header li a {
    padding: 20px 30px;
  }
  .header .menu-search .menu-box .menu {
    clear: none;
    text-align: left;
    max-height: none;
  }
  .header .menu-icon {
    display: none;
  }
  .menu {
    float: left;
  }
}
<header class="header">
  <a href="" class="logo">Celebyte</a>
  <div class="menu-search">
    <span class="search-box">
        <h5>Search Box</h5>
      </span>
    <span class="menu-box">
        <input class="menu-btn" type="checkbox" id="menu-btn" />
        <label class="menu-icon" for="menu-btn"
          ><span class="navicon"></span
        ></label>
        <ul class="menu">
          <li><a href="#work">Celebyte Gifting</a></li>
          <li><a href="#about">Track Order</a></li>
          <li><a href="#careers">All Categories</a></li>
          <li><a href="#contact">Login</a></li>
        </ul>
      </span>
  </div>
</header>

如上所示,我希望 SearchBox 和 MenuItems 在一行中,因此使用了 flex,但是,即使是汉堡包项目也获得了上述属性。我的意图是将汉堡包项目向左对齐。那么最好的解决方案是什么?

代码沙盒链接:https://codesandbox.io/s/vibrant-night-r7p4e

【问题讨论】:

  • 你想要左边的搜索框吗?
  • 我实际上想将汉堡包向左对齐
  • 请检查codeandbox链接...我已经更新了

标签: html css


【解决方案1】:

body {
  margin: 0;
  font-family: Helvetica, sans-serif;
  background-color: #f4f4f4;
}

a {
  color: #000;
}

.header {
  background-color: #fff;
  box-shadow: 1px 1px 4px 0 rgba(0, 0, 0, 0.1);
  position: fixed;
  width: 100%;
  z-index: 3;
}

.header ul {
  margin: 0;
  padding: 0;
  list-style: none;
  overflow: hidden;
  background-color: #fff;
}

.header li a {
  display: block;
  padding: 20px 20px;
  border-right: 1px solid #f4f4f4;
  text-decoration: none;
}

.header li a:hover,
.header .menu-btn:hover {
  background-color: #f4f4f4;
}

.header .logo {
  display: block;
  float: left;
  font-size: 2em;
  padding: 10px 20px;
  text-decoration: none;
}

.header .menu {
  clear: both;
  max-height: 0;
  transition: max-height 0.2s ease-out;
}

.header .menu-icon {
  cursor: pointer;
  display: inline-block;
  float: right;
  padding: 28px 20px;
  position: relative;
  user-select: none;
}

.header .menu-icon .navicon {
  background: #333;
  display: block;
  height: 2px;
  position: relative;
  transition: background 0.2s ease-out;
  width: 18px;
}

.header .menu-icon .navicon:before,
.header .menu-icon .navicon:after {
  background: #333;
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  transition: all 0.2s ease-out;
  width: 100%;
}

.header .menu-icon .navicon:before {
  top: 5px;
}

.header .menu-icon .navicon:after {
  top: -5px;
}

.header .menu-btn {
  display: none;
}

.header .menu-btn:checked~.menu {
  max-height: 240px;
}

.header .menu-btn:checked~.menu-icon .navicon {
  background: transparent;
}

.header .menu-btn:checked~.menu-icon .navicon:before {
  transform: rotate(-45deg);
}

.header .menu-btn:checked~.menu-icon .navicon:after {
  transform: rotate(45deg);
}

.header .menu-btn:checked~.menu-icon:not(.steps) .navicon:before,
.header .menu-btn:checked~.menu-icon:not(.steps) .navicon:after {
  top: 0;
}

.menu-search {
  display: flex;
  flex-wrap: wrap;
  width: calc(100% - 166.297px);
}

.search-box h5 {
  color: red;
}


/* 48em = 768px */

@media (min-width: 52em) {
  .header li {
    float: left;
  }
  .header li a {
    padding: 20px 30px;
  }
  .header .menu-search .menu-box .menu {
    clear: none;
    text-align: left;
    max-height: none;
  }
  .header .menu-icon {
    display: none;
  }
  .menu {
    float: left;
  }
}

.search-box {
  position: absolute;
  right: 10px;
}
<header class="header">
  <a href="" class="logo">Celebyte</a>
  <div class="menu-search">
    <span class="menu-box">
            <input class="menu-btn" type="checkbox" id="menu-btn" />
            <label class="menu-icon" for="menu-btn"><span class="navicon"></span></label>
    <ul class="menu">
      <li><a href="#work">Celebyte Gifting</a></li>
      <li><a href="#about">Track Order</a></li>
      <li><a href="#careers">All Categories</a></li>
      <li><a href="#contact">Login</a></li>
    </ul>
    </span>
    <span class="search-box">
            <h5>Search Box</h5>
        </span>
  </div>
</header>

【讨论】:

  • SearchBox 应该在汉堡菜单之前排在第一位,汉堡中的项目应该左对齐意味着在最左边
  • 看看当你删除 .menu-search 中的 flex 属性时,所有的项目都正确地向左对齐,而 SearchBox 改变了它的位置,这是不可取的......那怎么办......我需要与汉堡菜单对齐的搜索框以及在菜单中正确对齐的项目
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-08-25
  • 1970-01-01
  • 2021-05-28
  • 2021-05-01
相关资源
最近更新 更多