Animated Menubar coding - Website Design
Website Animated Menubar HTML
<menu class="menu">
<button class="menu__item active" style="--bgColorItem: #ff8c00;" >
<svg class="icon" viewBox="0 0 24 24">
<path d="M3.8,6.6h16.4"/>
<path d="M20.2,12.1H3.8"/>
<path d="M3.8,17.5h16.4"/>
</svg>
</button>
<button class="menu__item" style="--bgColorItem: #f54888;">
<svg class="icon" viewBox="0 0 24 24">
<path d="M6.7,4.8h10.7c0.3,0,0.6,0.2,0.7,0.5l2.8,7.3c0,0.1,0,0.2,0,0.3v5.6c0,0.4-0.4,0.8-0.8,0.8H3.8
C3.4,19.3,3,19,3,18.5v-5.6c0-0.1,0-0.2,0.1-0.3L6,5.3C6.1,5,6.4,4.8,6.7,4.8z"/>
<path d="M3.4,12.9H8l1.6,2.8h4.9l1.5-2.8h4.6"/>
</svg>
</button>
<button class="menu__item" style="--bgColorItem: #4343f5;" >
<svg class="icon" viewBox="0 0 24 24">
<path d="M3.4,11.9l8.8,4.4l8.4-4.4"/>
<path d="M3.4,16.2l8.8,4.5l8.4-4.5"/>
<path d="M3.7,7.8l8.6-4.5l8,4.5l-8,4.3L3.7,7.8z"/>
</button>
<button class="menu__item" style="--bgColorItem: #e0b115;" >
<svg class="icon" viewBox="0 0 24 24" >
<path d="M5.1,3.9h13.9c0.6,0,1.2,0.5,1.2,1.2v13.9c0,0.6-0.5,1.2-1.2,1.2H5.1c-0.6,0-1.2-0.5-1.2-1.2V5.1
C3.9,4.4,4.4,3.9,5.1,3.9z"/>
<path d="M4.2,9.3h15.6"/>
<path d="M9.1,9.5v10.3"/>
</button>
<button class="menu__item" style="--bgColorItem:#65ddb7;">
<svg class="icon" viewBox="0 0 24 24" >
<path d="M5.1,3.9h13.9c0.6,0,1.2,0.5,1.2,1.2v13.9c0,0.6-0.5,1.2-1.2,1.2H5.1c-0.6,0-1.2-0.5-1.2-1.2V5.1
C3.9,4.4,4.4,3.9,5.1,3.9z"/>
<path d="M5.5,20l9.9-9.9l4.7,4.7"/>
<path d="M10.4,8.8c0,0.9-0.7,1.6-1.6,1.6c-0.9,0-1.6-0.7-1.6-1.6C7.3,8,8,7.3,8.9,7.3C9.7,7.3,10.4,8,10.4,8.8z"/>
</svg>
</button>
<div class="menu__border"></div>
</menu>
<div class="svg-container">
<svg viewBox="0 0 202.9 45.5" >
<clipPath id="menu" clipPathUnits="objectBoundingBox" transform="scale(0.0049285362247413 0.021978021978022)">
<path d="M6.7,45.5c5.7,0.1,14.1-0.4,23.3-4c5.7-2.3,9.9-5,18.1-10.5c10.7-7.1,11.8-9.2,20.6-14.3c5-2.9,9.2-5.2,15.2-7
c7.1-2.1,13.3-2.3,17.6-2.1c4.2-0.2,10.5,0.1,17.6,2.1c6.1,1.8,10.2,4.1,15.2,7c8.8,5,9.9,7.1,20.6,14.3c8.3,5.5,12.4,8.2,18.1,10.5
c9.2,3.6,17.6,4.2,23.3,4H6.7z"/>
</clipPath>
</svg>
</div>
website Animated Menubar CSS
      html {
box-sizing: border-box;
--bgColorMenu : #1d1d27;
--duration:
      .7s;
}
html *,
html *::before,
html *::after {
box-sizing:
      inherit;
}
body{
margin: 0;
display: flex;
height:
      100vh;
overflow: hidden;
align-items: center;
justify-content:
      center;
background-color: #ffb457;
-webkit-tap-highlight-color:
      transparent;
transition: background-color var(--duration);
}
.menu{
margin:
      0;
display: flex;
/* Works well with 100% width */
width:
      32.05em;
font-size: 1.5em;
padding: 0 2.85em;
position:
      relative;
align-items: center;
justify-content: center;
background-color:
      var(--bgColorMenu);
}
.menu__item{
all: unset;
flex-grow:
      1;
z-index: 100;
display: flex;
cursor: pointer;
position:
      relative;
border-radius: 50%;
align-items: center;
will-change:
      transform;
justify-content: center;
padding: 0.55em 0 0.85em;
transition:
      transform var(--timeOut , var(--duration));
}
.menu__item::before{
content:
      "";
z-index: -1;
width: 4.2em;
height: 4.2em;
border-radius:
      50%;
position: absolute;
transform: scale(0);
transition:
      background-color var(--duration), transform var(--duration);
}
.menu__item.active
      {
transform: translate3d(0, -.8em , 0);
}
.menu__item.active::before{
transform:
      scale(1);
background-color: var(--bgColorItem);
}
.icon{
width:
      2.6em;
height: 2.6em;
stroke: white;
fill: transparent;
stroke-width:
      1pt;
stroke-miterlimit: 10;
stroke-linecap: round;
stroke-linejoin:
      round;
stroke-dasharray: 400;
}
.menu__item.active .icon
      {
animation: strok 1.5s reverse;
}
@keyframes strok {
100%
      {
stroke-dashoffset: 400;
}
}
.menu__border{
left:
      0;
bottom: 99%;
width: 10.9em;
height: 2.4em;
position:
      absolute;
clip-path: url(#menu);
will-change: transform;
background-color:
      var(--bgColorMenu);
transition: transform var(--timeOut ,
      var(--duration));
}
.svg-container {
width: 0;
height:
      0;
}
@media screen and (max-width: 50em) {
.menu{
font-size:
      .8em;
}
}
Animated Menu bar Javascript
"use
      strict"; 
      const body = document.body;
 
          const bgColorsBody = ["#ffb457", "#ff96bd", "#9999fb",
      "#ffe797", "#cffff1"];
    const menu =
      body.querySelector(".menu");
      const menuItems =
      menu.querySelectorAll(".menu__item");
   
 
          const menuBorder = menu.querySelector(".menu__border");
 
          let activeItem = menu.querySelector(".active");
 
          function clickItem(item, index) {
      enu.style.removeProperty("--timeOut");
      if
      (activeItem == item) return;
if (activeItem) {
 
      activeItem.classList.remove("active");
  }
 
           item.classList.add("active");
 body.style.backgroundColor
      = bgColorsBody[index];
activeItem = item;
 offsetMenuBorder(activeItem,
      menuBorder);
    
}
  function
      offsetMenuBorder(element, menuBorder) {
  const offsetActiveItem
      = element.getBoundingClientRect();
      const left =
      Math.floor(offsetActiveItem.left - menu.offsetLeft -
      (menuBorder.offsetWidth  - offsetActiveItem.width) / 2) + 
      "px";
    menuBorder.style.transform =
      `translate3d(${left}, 0 , 0)`;
 
}
 
        
offsetMenuBorder(activeItem, menuBorder);
 
          menuItems.forEach((item, index) => {
   
        item.addEventListener("click", () => clickItem(item, index));
 
       
    
})
     
      window.addEventListener("resize", () => {
    
 
           offsetMenuBorder(activeItem, menuBorder);
 
           menu.style.setProperty("--timeOut", "none");
 
       
   
});
    
Mobile navigation Bar concept Website Design
Mobile navigation Bar HTML
    <div class="phone">
  <div
    class="page">Home</div>
  
 
    <nav>
    <div class="wave-wrap">
 
        <svg version="1.1" id="wave"
    xmlns="http://www.w3.org/2000/svg"
    xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 119 26">
 
            <path class="path" 
   
               
    d="M120.8,26C98.1,26,86.4,0,60.4,0C35.9,0,21.1,26,0.5,26H120.8z"/>
 
          </svg>
    </div>
 
      <ul class="list-wrap">
      <li
    data-color="linear-gradient(to top, #09203f 0%, #537895 100%)"
    title="Home">
        <i class="icon
    ion-ios-home"></i>
      </li>
 
        <li data-color="#ff6b81" title="Profile">
 
          <i class="icon ion-ios-person"></i>
 
        </li>
      <li
    data-color="#7bed9f" title="Get a beer!">
     
      <i class="icon ion-ios-beer"></i>
   
      </li>
      <li data-color="#70a1ff"
    title="Files">
        <i class="icon
    ion-ios-folder-open"></i>
      </li>
 
        <li data-color="#dfe4ea" title="Settings">
 
          <i class="icon ion-ios-settings"></i>
 
        </li>
    </ul>
 
    </nav>
  
</div>
  
mobile navigation Bar CSS
    *{
  margin:0;
  padding:0;
 
    box-sizing:border-box;
}
$black: #2f3542;
$grey: #a4b0be;
body{
 
    display:flex;
  justify-content:center;
 
    align-items:center;
  min-height:100vh;
 
    transition:background .5s cubic-bezier(0.23, 1, 0.32, 1);
}
nav{
 
    width:440px;
}
// WAVE
.wave-wrap{
 
    position:relative;
  width:100%;
  height:33px;
 
    overflow:hidden;
  margin-bottom:0;
  
 
    #wave{
    position:absolute;
   
    width:150px;
    transform-origin:bottom;
   
    transform:scaleY(0.8);
    transition:all .6s
    cubic-bezier(0.23, 1, 0.32, 1);
    
   
    .path{
      fill:$black;
    }
 
    }
}
// LIST
.list-wrap{
  display:flex;
 
    width:100%;
  height:80px;
  background:$black;
 
    list-style:none;
  justify-content:space-around;
 
    padding: 0 20px;
  
  li{
   
    cursor:pointer;
    position:relative;
   
    width:100%;
    height:100%;
    display:
    flex;
    justify-content: center;
   
    align-items: center;
    transition:all .6s
    cubic-bezier(0.23, 1, 0.32, 1);
    
   
    i{
      position:relative;
     
    font-size:1.5em;
      color:$grey;
   
      z-index:5;
      transition:all .6s
    cubic-bezier(0.23, 1, 0.32, 1);
    }
 
      
    &:before{
     
    content:"";
      position:absolute;
   
      background:green;
      height:80%;
 
        width:80%;
      left:10%;
 
        top:10%;
      border-radius:50%;
 
        z-index:0;
      transform:scale(0);
 
        transition:all .6s cubic-bezier(0.23, 1, 0.32, 1);
 
      }
    
    &.active{
 
        margin-top:-10px;
      
 
        i{
        color:$black;
 
        }
      
     
    &:before{
        transform:scale(1);
 
        }
    }
    
 
      &:nth-child(1){&:before{background:#537895}}
 
      &:nth-child(2){&:before{background:#ff6b81}}
 
      &:nth-child(3){&:before{background:#7bed9f}}
 
      &:nth-child(4){&:before{background:#70a1ff}}
 
      &:nth-child(5){&:before{background:#dfe4ea}}
  }
}
//
    ▼ this is not necessary for the navigation ▼
.phone{
 
    height:300px;
  border:7px solid rgba(0, 0, 0, 0.05);
 
    border-radius:20px;
  overflow:hidden;
 
    display:flex;
  align-items:flex-end;
 
    flex-direction:column;
  font-family: 'Montserrat', sans-serif;
  
 
    .page{
    height:327px;
    width:100%;
 
      display:flex;
    justify-content:center;
 
      align-items:center;
    font-size:3em;
 
      color:rgba(0, 0, 0, 0.1);
   
    text-transform:uppercase;
    letter-spacing:5pt;
 
      padding-top:50px;
  }}
  
mobile navigation Bar JAVASCRIPT
    // set the first nav item as active
var dis = $(".list-wrap
    li").eq(0);
// align the wave
align(dis);
// align the wave
    on click
$(".list-wrap li").click(function(){
  dis =
    $(this);
  
  align(dis);
});
$('body').on('keydown',function(e){
 
      var code = e.keyCode || e.which;
  
   
    if(code == 9) {
      
     
    if(dis.is(':last-child')){
        $(".list-wrap
    li:nth-child(1)").trigger("click");
      }
 
        else{
       
    dis.next().trigger("click");
      }
   
      
    } 
});
$("body").keydown(function(e)
    {
  if(e.keyCode == 37) { // left
   
    $("#showroom").animate({
      left: "-=980"
 
      });
  }
  else if(e.keyCode == 39) { // right
 
      $("#showroom").animate({
      left: "+=980"
 
      });
  }
});
function align(dis){
  
 
    // get index of item
  var index = dis.index() + 1;
  
 
    // add active class to the new item
  $(".list-wrap
    li").removeClass("active");
  dis.delay(100).queue(function() {
 
      dis.addClass('active').dequeue();
  });
  
 
    // move the wave
  var left = index * 80 - 98;
  
 
    $("#wave").css('left', left);
  
  // ▼ this is not
    necessary for the navigation ▼
  
  // set the
    background color
  var color = dis.data('color');
 
    $("body").css('background', color);
  
  // set the
    text
  $(".page").text(dis.attr("title"));
}
  
Post a Comment