带有菜单项的侧边栏问题

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

我找到了一个我喜欢的侧边栏。我将添加链接以感谢原始创建者。 CSS 侧边栏菜单示例 然后是纯 CSS 飞行侧边栏。

现在我正在摆弄它,最终我开始删除一些项目。 当菜单项低于 4 时,我开始注意到一些奇怪的行为。 当只有 1 件商品时,这一点尤其引人注目。请参阅下图。

这是代码,下面有一个 codepen 链接 html部分

  <section class="app">
  <aside class="sidebar">
    <header>
      Menu
    </header>
    <nav class="sidebar-nav">

      <ul>
        <li>
          <a href="#"><i class="ion-bag"></i> <span>Menu 1</span></a>
          <ul class="nav-flyout">
            <li>
              <a href="#"><i class="ion-ios-color-filter-outline"></i>Menu Item 1</a>
            </li>
            <li>
              <a href="#"><i class="ion-ios-clock-outline"></i>Menu Item 2</a>
            </li>
            <li>
              <a href="#"><i class="ion-android-star-outline"></i>Menu Item 3</a>
            </li>
            <li>
              <a href="#"><i class="ion-heart-broken"></i>Menu Item 4</a>
            </li>
          </ul>
        </li>
        <li>
          <a href="#"><i class="ion-ios-settings"></i> <span class="">Menu 2</span></a>
          <ul class="nav-flyout">
            <li>
              <a href="#"><i class="ion-ios-alarm-outline"></i>Menu Item 1</a>
            </li>
            <li>
              <a href="#"><i class="ion-ios-camera-outline"></i>Menu Item 2</a>
            </li>
            <li>
              <a href="#"><i class="ion-ios-chatboxes-outline"></i>Menu Item 3</a>
            </li>
          </ul>
        </li>
        <li>
          <a href="#"><i class="ion-ios-briefcase-outline"></i> <span class="">Menu 3</span></a>
          <ul class="nav-flyout">
            <li>
              <a href="#"><i class="ion-ios-flame-outline"></i>Menu Item 1</a>
            </li>
            <li>
              <a href="#"><i class="ion-ios-lightbulb-outline"></i>Menu Item 2</a>
            </li>
          </ul>
        </li>
        <li>
          <a href="#"><i class="ion-ios-analytics-outline"></i> <span class="">Menu 4</span></a>
          <ul class="nav-flyout">
            <li>
              <a href="#"><i class="ion-ios-timer-outline"></i>Menu Item 1</a>
            </li>
          </ul>
        </li>
        <li>
          <a href="#"><i class="ion-ios-paper-outline"></i> <span class="">Menu 5</span></a>
          <ul class="nav-flyout">
            <li>
              <a href="#"><i class="ion-ios-filing-outline"></i>Menu Item 1</a>
            </li>
            <li>
              <a href="#"><i class="ion-ios-information-outline"></i>Menu Item 2</a>
            </li>
            <li>
              <a href="#"><i class="ion-ios-paperplane-outline"></i>Menu Item 3</a>
            </li>
            <li>
              <a href="#"><i class="ion-android-star-outline"></i>Menu Item 4</a>
            </li>
             <li>
              <a href="#"><i class="ion-android-star-outline"></i>Menu Item 5</a>
            </li>
            <li>
              <a href="#"><i class="ion-android-star-outline"></i>Menu Item 6</a>
            </li>
            <li>
              <a href="#"><i class="ion-android-star-outline"></i>Menu Item 7</a>
            </li>
            <li>
              <a href="#"><i class="ion-android-star-outline"></i>Menu Item 8</a>
            </li>
            
          </ul>
        </li>
      </ul>
    </nav>
  </aside>
</section>

CSS部分

@import url(https://fonts.googleapis.com/css?family=Source+Sans+Pro:400,300,600);

body {
  font-family: "Lato";
  font-size: 100%;
  overflow-y: scroll;
  font-family: sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  background-color: #fefefe;
}

a {
  text-decoration: none;
  -webkit-transition: all 0.6s ease;
  -moz-transition: all 0.6s ease;
  transition: all 0.6s ease;
}
a:hover {
  -webkit-transition: all 0.6s ease;
  -moz-transition: all 0.6s ease;
  transition: all 0.6s ease;
}

.app {
  height: 100vh;
}

/* -------------
Sidebar
----------------*/
.sidebar {
  position: absolute;
  width: 17em;
  height: 100%;
  top: 0;
  overflow: hidden;
  background-color: #19222a;
  -webkit-transform: translateZ(0);
  visibility: visible;
  -webkit-backface-visibility: hidden;
}
.sidebar header {
  background-color: #09f;
  width: 100%;
  display: block;
  padding: 0.75em 1em;
}

/* -------------
Sidebar Nav
----------------*/
.sidebar-nav {
  position: fixed;
  background-color: #19222a;
  height: 100%;
  font-weight: 400;
  font-size: 1.2em;
  overflow: auto;
  padding-bottom: 6em;
  z-index: 9;
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
  /* -------------
  Chev elements
  ----------------*/
  /* -------------
  Nav-Flyout
  ----------------*/
  /* -------------
  Hover
  ----------------*/
}
.sidebar-nav ul {
  list-style: none;
  display: block;
  padding: 0;
  margin: 0;
}
.sidebar-nav ul li {
  margin-left: 0;
  padding-left: 0;
  display: inline-block;
  width: 100%;
  /* -------------
  Sidebar: icons
  ----------------*/
}
.sidebar-nav ul li a {
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.75em;
  padding: 1.05em 1em;
  position: relative;
  display: block;
}
.sidebar-nav ul li a:hover {
  background-color: rgba(0, 0, 0, 0.9);
  -webkit-transition: all 0.6s ease;
  -moz-transition: all 0.6s ease;
  transition: all 0.6s ease;
}
.sidebar-nav ul li i {
  font-size: 1.8em;
  padding-right: 0.5em;
  width: 9em;
  display: inline;
  vertical-align: middle;
}
.sidebar-nav > ul > li > a:after {
  content: "";
  font-family: ionicons;
  font-size: 0.5em;
  width: 10px;
  color: #fff;
  position: absolute;
  right: 0.75em;
  top: 45%;
}
.sidebar-nav .nav-flyout {
  position: absolute;
  background-color: #080D11;
  z-index: 9;
  left: 2.5em;
  top: 0;
  height: 100vh;
  -webkit-transform: translateX(100%);
  -moz-transform: translateX(100%);
  -ms-transform: translateX(100%);
  -o-transform: translateX(100%);
  transform: translateX(100%);
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
.sidebar-nav .nav-flyout a:hover {
  background-color: rgba(255, 255, 255, 0.05);
}
.sidebar-nav ul > li:hover .nav-flyout {
  -webkit-transform: translateX(0);
  -moz-transform: translateX(0);
  -ms-transform: translateX(0);
  -o-transform: translateX(0);
  transform: translateX(0);
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

示例

有人知道为什么会发生这种行为以及如何解决这个问题吗?

我一直在使用 google 只是为了看看一些 CSS 的作用。以及菜单是如何构建的。 我注意到菜单也存在于可见菜单旁边,并且它在正确的时刻向左滑动。 我还注意到 CSS 部分 .sidebar-nav .nav-flyout { 部分定位在菜单中。 我只是不明白为什么更多的菜单项会对这种行为产生影响。 希望有人能帮助我。

html css sidebar
2个回答
0
投票

我意识到你必须设置属性:width: 100vh; .nav-flyout 类。代码将保留:

.sidebar-nav .nav-flyout {
  position: absolute;
  background-color: #080D11;
  z-index: 9;
  left: 2.5em;
  top: 0;
  height: 100vh;
  width: 100vh;
  -webkit-transform: translateX(100%);
  -moz-transform: translateX(100%);
  -ms-transform: translateX(100%);
  -o-transform: translateX(100%);
  transform: translateX(100%);
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

据我了解,它与 Z-index 有关,并且元素不会占据整个屏幕,因此可以看到元素。


0
投票

您正在使用

transform: translateX(100%)
将子菜单滑出视图。有问题的元素似乎是菜单 4 的菜单项。由于某种原因,它比其他元素更窄,这使得它在应用
translateX(100%)
时不会移动那么远。

要解决此问题,请将 100% 更改为某个绝对长度,或者显式设置子菜单的宽度,因此“100%”对所有子菜单的计算结果都是相同的长度。

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