0

我正在做我的第一个 Rails 项目,我真的很难让滑动菜单在 Bourbon / Neat 上运行。我最近的尝试围绕着尝试使用 CSS :target 和 Neat 的 Shift() 混合。我要分解的地方是在哪里/如何包含 mixin 以及在哪里/如何实例化实际的班次。这就是我尝试纯 CSS 的地方......

#nav
  @include span-columns(1)
  position: fixed
  left: -240px
  top: 0
  bottom: 0
  background-color: #654
  border-right: 50px solid #765
  box-shadow: 4px 0 5px rgba(0,0,0,0.2)
  z-index: 1
  cursor: pointer

#nav:after
  position: absolute
  content: ' '
  width: 0
  right: -70px
  top: 50%
  border-width: 15px 10px
  border-style: solid
  border-color: transparent transparent transparent #765

#holder
  @include span-columns(14)
  position: fixed 
  left: 0 
  top: 0 
  right: 0 
  bottom: 0 
  overflow: auto 
  z-index: 0  
  -webkit-transform-origin: 0 50% 
  -moz-transform-origin: 0 50% 
  -ms-transform-origin: 0 50% 
  -o-transform-origin: 0 50% 
  transform-origin: 0 50% 

#holder:after
  position: absolute  
  content: ' '  
  left: 100% 
  top: 0 
  right: 0 
  bottom: 0 
  background-image: -webkit-linear-gradient(right, rgba(0,0,0,0.2) 0%, transparent 100%) 
  background-image: -moz-linear-gradient(right, rgba(0,0,0,0.2) 0%, transparent 100%) 
  background-image: -ms-linear-gradient(right, rgba(0,0,0,0.2) 0%, transparent 100%) 
  background-image: -o-linear-gradient(right, rgba(0,0,0,0.2) 0%, transparent 100%) 
  background-image: linear-gradient(right, rgba(0,0,0,0.2) 0%, transparent 100%) 
  pointer-events: none 

这描述了两个元素( nav 和 holder )的定位。从理论上讲,导航几乎完全脱离画布并在悬停时滑入。然而,这根本没有发生。正在发生的事情是导航直接显示在持有人身上,持有人被下拉到导航下方。没有什么是脱离画布的,也没有任何变化。下面我将发布转换的 CSS 和生成的 html。

#holder, #holder:after, #hav, #nav:after
  -webkit-transition: all 600ms ease
  -moz-transition: all 600ms ease
  -ms-transition: all 600ms ease
  -o-transition: all 600ms ease
  transition: all 600ms ease

#nav:hover
  left: 0

#nav:hover ~ #holder
  -webkit-transform: translateX(16em) perspective(600px) rotateY(10deg)
  -moz-transform: translateX(16em) perspective(600px) rotateY(10deg)
  -ms-transform: translateX(16em) perspective(600px) rotateY(10deg)
  -o-transform: translateX(16em) perspective(600px) rotateY(10deg)
  transform: translateX(16em) perspective(600px) rotateY(10deg)

#nav:hover ~ #holder:after
  left: 60%

和..

     <body id="body">
    <div class="nav">
  <ul>
    <li>First Link</li>
    <li>Second Link</li>
    <li>Third Link</li>
    <li>Fourth Link</li>
  </ul>
</div>
    <div class="holder">
  <div id="logo">
    <a href="index.html"><img alt="LoGo" src="/assets/etlogo.png" /></a>
  </div> 
  <div id="tsol">
  </div>

我已经查看了 Neat 的 Shift() mixin,但是关于它的文档很少。老实说,我不知道这是否对我有用,或者如果是这样的话如何实施。整洁的文档中总共有 3 行。任何帮助、提示,或者,真的,任何不是非常侮辱的东西都将不胜感激。

4

1 回答 1

1

@Blind Fish - 这是许多组件的示例,包括由波旁威士忌的创造者构建的滑动导航:

http://refills.bourbon.io/

很抱歉没有具体解决您的问题,但这可能是您进一步定制的一个很好的起点。

于 2014-04-19T00:31:45.133 回答