Humburger Navigation Smaple01

基本的なハンバーガーナビのコード。
mobile基準のレスポンシブ仕様。
モバイル表示の際にメニュー下部にSNS(Instagram)アイコン表示させている。
(Kureai BAKERYのsammpleより)

HTMLは以下

<div id="nav-btn">
	<div class="nav_toggle">
		<span></span>
		<span></span>
		<span></span>
	</div>
	</div>
<nav id="global_nav">
	<ul class="nav_list">
		<li class="nav_list-item"><a href="">CONCEPT</a></li>
		<li class="nav_list-item"><a href="">LINE UP</a></li>
		<li class="nav_list-item"><a href="">TOPICS</a></li>
		<li class="nav_list-item"><a href="#access">ACCESS</a></li>
		<li class="nav_list-item"><a href="">CONTACT</a></li>
	</ul>
		<div class="header_sns"><a href=""><img src="./images/insta_circle_bk.svg"></a></div>
	</nav>

SCSS以下
scssなので_mixin.scssでmedia query設定後読込み

/*    navigation     */
#global_nav {
  box-sizing: border-box;
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  font-family: 'Roboto Slab', serif;
  display: block;
  transform: translate(100%);
  transition: .5s;
  background-color: rgba(44, 44, 44, 0.786);
  z-index: 999;
  @include m.mq(tab) {
    padding: 70px 0 10px 0;
    position: relative;
    width: 700px; 
    height: 120px;
    top: auto;
    right: auto;
    display: flex;
    transform: none;
    transition: none;
    background-color: #FFF;
  }
}
#global_nav.open {
  transform: translateZ(0);
}
.nav_list{
    padding-top: 120px;
    width: 100%;       
  &-item {
    padding: 15px 30px;
    display: block;    
    font-size: 110%;
    text-align: center;
a {
  position: relative;
  color: v.$color-wh;
  &:hover {
    font-size: 90%;
    }
  }
}
@include m.mq(tab) {
  padding-top: 0;
  height: 45px;
  position: relative;
  display: flex;
  justify-content:space-between;
  flex-wrap: wrap;
  &-item {
    padding: 10px 10px;
    font-size: 90%;  
    a {
      display: block;
      font-size: 90%;
      color: v.$color-text;
      &::after {
        position: absolute;
        left: 0;
        content: '';
        width: 100%;
        height: 2px;
        background: v.$color-bk;
        bottom: -7px;
        transform: scale(0, 1);
        transform-origin: left top;
        transition: transform 0.3s; 
      }
    &:hover {
      color: v.$color-text;
      &::after {
        transform: scale(1, 1);
    }
    }
  }
      }
    }
  }

#nav-btn {
  top: 15px;
  right: 20px;
  transition: .03s;
  position: fixed;
  z-index: 9999;
  cursor: pointer;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  @include m.mq(tab) {
    display: none;
  }
}
#nav-btn.active .nav_toggle {
      span {
        &:nth-of-type(1) {
          transform: translateY(7px) rotate(-45deg);
          background-color: #fff;
        }
        &:nth-of-type(2) {
          opacity: 0;
        }
        &:nth-of-type(3) {
          transform: translateY(-7px) rotate(45deg);
          background-color: #fff;
        }
      }
    }

.nav_toggle {
  width: 40px;
  height: 16px;
  position: relative;
  span {
    display: inline-block;
    position: absolute;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #363636;
    transition: all 0.5s;
    &:nth-of-type(1) {
      top: 0;
    }
    &:nth-of-type(2) {
      top: 7px;
    }
    &:nth-of-type(3) {
      bottom: 0;
    }
  }
}

javascript jQuery利用版
ページ内リンクがあった場合でもnavが消えるようにしている。

jQuery(function() {
//navigation
   jQuery(window).on('load', function() {
   jQuery('#nav-btn').on('click', function () {
    if (jQuery(this).hasClass('active')) {
            jQuery(this).removeClass('active');
            jQuery('#global_nav').removeClass('open');
    } else {
            jQuery(this).addClass('active');
            jQuery('#global_nav').addClass('open');
    }
//以下、メニュー部分をクリックしてもglobal_navは消える
    jQuery('#global_nav a').on('click', function() {
        jQuery('#global_nav').removeClass('open');
        jQuery("#nav-btn").removeClass('active');
      })
});

jQueryを利用しない版

window.onload = function() {
    const nav = document.getElementById('global_nav');
    const btn = document.getElementById('nav-btn');
    btn.addEventListener('click', function() {
        nav.classList.toggle('open');
        btn.classList.toggle('active');
    });
    nav.addEventListener('click', function() {
        nav.classList.remove('open');
        btn.classList.remove('active');
    })
};
PAGE TOP