有没有办法让我的汉堡菜单显示在右侧? (我可以在那里买到汉堡包,但不是弹出菜单)

问题描述 投票:0回答:1

HTML

<div class="hamburger-menu">
    <input id="menu__toggle" type="checkbox" />
    <label class="menu__btn" for="menu__toggle">
      <span></span>
    </label>

    <ul class="menu__box">
      <li><a class="menu__item" href="#">Home</a></li>
            <li><a class="menu__item" href="#">About</a></li>
            <li><a class="menu__item" href="#">Team</a></li>
            <li><a class="menu__item" href="#">Contact</a></li>
            <li><a class="menu__item" href="#">Twitter</a></li>
    </ul>
  </div>

CSS

#menu__toggle {
  opacity: 0;
}
#menu__toggle:checked + .menu__btn > span {
  transform: rotate(45deg);
}
#menu__toggle:checked + .menu__btn > span::before {
  top: 0;
  transform: rotate(0deg);
}
#menu__toggle:checked + .menu__btn > span::after {
  top: 0;
  transform: rotate(90deg);
}
#menu__toggle:checked ~ .menu__box {
  left: 0 !important;
}
.menu__btn {
  position: fixed;
  top: 20px;
  right: 20px;
  width: 26px;
  height: 26px;
  cursor: pointer;
  z-index: 1;
}
.menu__btn > span,
.menu__btn > span::before,
.menu__btn > span::after {
  display: block;
  position: absolute;
  width: 100%;
  height: 2px;
  background-color: #616161;
  transition-duration: .25s;
}
.menu__btn > span::before {
  content: '';
  top: -8px;
}
.menu__btn > span::after {
  content: '';
  top: 8px;
}
.menu__box {
  display: block;
  position: fixed;
  top: 0;
  left: -100%;
  width: 300px;
  height: 100%;
  margin: 0;
  padding: 80px 0;
  list-style: none;
  background-color: #ECEFF1;
  box-shadow: 2px 2px 6px rgba(0, 0, 0, .4);
  transition-duration: .25s;
}
.menu__item {
  display: block;
  padding: 12px 24px;
  color: #333;
  font-family: 'Roboto', sans-serif;
  font-size: 20px;
  font-weight: 600;
  text-decoration: none;
  transition-duration: .25s;
}
.menu__item:hover {
  background-color: #CFD8DC;
}

用 css 制作的汉堡包图标位于右侧且功能齐全,但我似乎无法在那里获得菜单 我希望菜单背景及其中的内容位于屏幕的右侧,而不是默认的左侧。 当然,在这种情况下,我也希望动画来自右侧。

我试过的

Under menu__box, float: right;
Under menu__box, change left: -100%; to right: -100%;

以及删除 -

html css position hamburger-menu
1个回答
0
投票

我变了

#menu__toggle:checked ~ .menu__box {
  left: 0 !important;
}

#menu__toggle:checked ~ .menu__box {
  right: 0 !important;
}

然后左变:-100%;向右:-100%;

我完全查看了这行代码,我很抱歉,但希望其他人得到帮助

© www.soinside.com 2019 - 2024. All rights reserved.