Бутстрап 3 и меню

Я хотел бы реализовать Mmenu для Bootstrap 3, но я застрял. Я хочу иметь верхнюю навигацию и при свертывании хочу, чтобы она переключалась в левое скользящее меню. Заранее спасибо за помощь.

РЕДАКТИРОВАТЬ: Я сделал это: https://github.com/purgeru/mmenu-Bootstrap-3. Если кто-то хочет внести свой вклад.

1 ответ

Решение

Это можно сделать без mmenu, добавив немного CSS.

Я бы посоветовал вам создать 2 разных nav:

  • .navbar.navbar-fixed-top за -sm, -md а также -lg приборы
  • .sidebar-offcanvas за -xs приборы

Посмотрите этот Bootply для рабочего примера, основанного на шаблоне Offcanvas.

Прокомментированный пример:

<!-- Classic nav -->
<div class="navbar navbar-fixed-top navbar-inverse" role="navigation">
  <div class="container">
    <div class="navbar-header">
      <!-- We change data-toggle to "offcanvas" -->
      <button type="button" class="navbar-toggle" data-toggle="offcanvas">
        <span class="sr-only">Toggle navigation</span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
      </button>
      <a class="navbar-brand" href="#">Project name</a>
    </div>
    <div class="collapse navbar-collapse">
      <ul class="nav navbar-nav">
        <li class="active"><a href="#">Home</a></li>
        <li><a href="#about">About</a></li>
        <li><a href="#contact">Contact</a></li>
      </ul>
    </div>
  </div>
</div>

<div class="container">

  <!-- You can use .row-offcanvas-left or .row-offcanvas-right -->
  <div class="row row-offcanvas row-offcanvas-left">

    <!-- Here is the offcanvas nav, with .visible-xs class -->
    <div class="col-xs-6 visible-xs sidebar-offcanvas" id="sidebar" role="navigation">
      <div class="list-group">
        <a href="#" class="list-group-item active">Home</a>
        <a href="#" class="list-group-item">About</a>
        <a href="#" class="list-group-item">Contact</a>
      </div>
    </div>

    <div class="col-12">
      Content
    </div>

  </div>

</div>

Вам понадобится несколько CSS:

/*
 * Off Canvas
 * --------------------------------------------------
 */
@media screen and (max-width: 767px) {
  .row-offcanvas {
    position: relative;
    -webkit-transition: all 0.25s ease-out;
    -moz-transition: all 0.25s ease-out;
    transition: all 0.25s ease-out;
  }

  .row-offcanvas-right .sidebar-offcanvas { right: -50%; }
  .row-offcanvas-right .sidebar-offcanvas .list-group { padding-right: 10px; }
  .row-offcanvas-right.active { right: 50%; }

  .row-offcanvas-left .sidebar-offcanvas { left: -50%; }
  .row-offcanvas-left .sidebar-offcanvas .list-group { padding-left: 10px; }
  .row-offcanvas-left.active { left: 50%; }

  .sidebar-offcanvas {
    position: absolute;
    top: 0;
    width: 50%; /* 6 columns */
  }
}

И несколько строк JS:

$(document).ready(function() {
  $('[data-toggle=offcanvas]').click(function() {
    $('.row-offcanvas').toggleClass('active');
  });
});
Другие вопросы по тегам