带隐藏侧边栏的垂直多面板UI界面布局

这是一款使用jQueryCSS3制作的带隐藏侧边栏的垂直多面板UI界面布局。这个UI界面使用汉堡包图标作为隐藏菜单触发按钮,点击它时菜单会从上往下滑出。点击相应的菜单项可以直接跳转到相应的面板上。另外也可以通过鼠标上下滚动来切换到各个面板。

制作方法

HTML结构

导航菜单放置在一个<nav>元素中,.burger元素是汉堡包图标,汉堡包的线条有伪元素来制作,以便于制作汉堡包图标动画。菜单项有一组无序列表组成。

<nav class="nav">
  <div class="burger">
    <div class="burger__patty"></div>
  </div>

  <ul class="nav__list">
    <li class="nav__item">
      <a href="#1" class="nav__link c-blue"><i class="fa fa-camera-retro"></i></a>
    </li>
    <li class="nav__item">
      <a href="#2" class="nav__link c-yellow scrolly"><i class="fa fa-bolt"></i></a>
    </li>
    <li class="nav__item">
      <a href="#3" class="nav__link c-red"><i class="fa fa-music"></i></a>
    </li>
    <li class="nav__item">
      <a href="#4" class="nav__link c-green"><i class="fa fa-paper-plane"></i></a>
    </li>
  </ul>
</nav>                
              

页面的每一个面板由一个section.panel制作。

<section class="panel">
  <article class="panel__wrapper">
    <div class="panel__content">
      // content here
     </div>
  </article>
</section>                
              
CSS样式

汉堡包导航使用position: fixed将它固定在页面的左上角。菜单中的无序列表初始化时使用translateY:-100%;将其隐藏,当汉堡包图标被点击时,在将它移动会屏幕中。

.nav {
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100px;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
.nav__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-flow: column wrap;
      -ms-flex-flow: column wrap;
          flex-flow: column wrap;
  height: 85vh;
  -webkit-transform: translate(0, -100%);
      -ms-transform: translate(0, -100%);
          transform: translate(0, -100%);
  -webkit-transition: all 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
          transition: all 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.nav__list--active {
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
}          
              

每一个内容面板section.panel都设置了最小高度min-height: 100vh;,使它们可以填满整个视口。每一个面板中的内容布局都使用flexbox来制作,类似下面的样子:

.panel {
  // ...
  display: flex;
  align-items: center; // 垂直居中
  justify-content: center; // 水平居中
}                
              
JAVASCRIPT

在jQuery代码中,对于汉堡包导航只是简单的在它被点击时切换它的class。

var menu = document.querySelector('.nav__list');
  var burger = document.querySelector('.burger');              
var openMenu = function () {
    burger.classList.toggle('burger--active');
    menu.classList.toggle('nav__list--active');
};           
              

每一个section中的内容在切换到该section时都带有一些动画效果。这是通过比较section.panel元素的$(document).scrollTop()值和.offset().top值来实现的。当.offset().top值小于$(document).scrollTop()值的时候,就为这个section的内容添加一个指定的class,使内容产生动画效果。否则,将这个class移除。

var scrollFx = function () {
      var ds = doc.scrollTop();
      var of = vh / 4;
      for (var i = 0; i < panel.length; i++) {
          if (window.CP.shouldStopExecution(1)) {
              break;
          }
          if (panel.eq(i).offset().top < ds + of) {
              panel.eq(i).find('.panel__content').addClass('panel__content--active');
          } else {
              panel.eq(i).find('.panel__content').removeClass('panel__content--active');
          }
      }
      window.CP.exitedLoop(1);
  };
  var scrolly = function (e) {
      e.preventDefault();
      var target = this.hash;
      var $target = $(target);
      $('html, body').stop().animate({ 'scrollTop': $target.offset().top }, 300, 'swing', function () {
          window.location.hash = target;
      });
  };
  var init = function () {
      burger.addEventListener('click', openMenu, false);
      window.addEventListener('scroll', scrollFx, false);
      window.addEventListener('load', scrollFx, false);
      $('a[href^="#"]').on('click', scrolly);
  };                
              

在线预览    源码下载

爱编程-编程爱好者经验分享平台
版权所有 爱编程 © Copyright 2012. All Rights Reserved.
闽ICP备12017094号-3