Giter Site home page Giter Site logo

amenhotep19 / vue-burger-menu Goto Github PK

View Code? Open in Web Editor NEW

This project forked from mbj36/vue-burger-menu

0.0 3.0 0.0 242 KB

๐Ÿ” An off-canvas sidebar Vue component - https://vue-burger-menu.netlify.com/

License: MIT License

JavaScript 3.22% HTML 3.96% Vue 92.82%

vue-burger-menu's Introduction

vue-burger-menu code style: prettier

npm

Tweet

An off-canvas sidebar Vue component with a collection of effects and styles using CSS transitions and SVG path animations.

Demo & examples

Live demo - https://vue-burger-menu.netlify.com/

To build the examples locally, run:

npm i 
npm run serve
yarn 
yarn serve

Then open localhost:8080 in a browser

Installation

npm install vue-burger-menu --save
yarn add vue-burger-menu

Usage

Items should be passed as child elements of the components

import { Slide } from 'vue-burger-menu'  // import the CSS transitions you wish to use, in this case we are using `Slide`

export default {
    components: {
        Slide // Register your component
    }
}

In your template

<template>
    <Slide>
      <a id="home" href="#"> 
        <span>Home</span>  
      </a>
    </Slide>
</template>

Animations

The example above imported slide which renders a menu that slides in on the page when the burger icon is clicked. To use a different animation you can subsitute slide with any of the following

  • slide
  • scaleDown
  • scaleRotate
  • reveal
  • push
  • pushRotate

ATTENTION - the below animations are in WIP

  • fallDown
  • stack
  • elastic
  • bubble

Properties

Some animation require certain other elements on your page

  • Page wrapper - an element wrapping the rest of the content on yur page, placed after the menu component
<Menu/>

<main id="page-wrap">
.
.
</main>
  • Outer container called app - an element containing everything including the menu component
<div id="app">
    <Menu/>
    <main id="page-wrap">
    .
    .
    .
    </main>
</div>

Check this table to see which animations require these elements:

Animation pageWrapId appId
slide
push โœ“ โœ“
pushRotate โœ“ โœ“
scaleDown โœ“ โœ“
scaleRotate โœ“ โœ“
reveal โœ“ โœ“

Position

The menu opens from left by default. To have it open from the right, use the right prop. It's just a boolean so you don't need to specify a value.

<Slide right/>

Width

You can specify the width of the menu with the width prop. The default is 300px

<Slide width="400">

Open state

You can control whether the sidebar is open or closed with the isOpen prop. This is useful if you need to close the menu after a user clicks on an item in it, for example, or if you want to open the menu from some other button in addition to the standard burger icon. The default value is false

// To render the menu open

<Slide isOpen>

Close on Escape

By default, the menu will close when the Escape key is pressed. To disable this behavior, you can pass the disableCloseOnEsc prop. This is useful in cases where you want the menu to be open all the time, for example if you're implementing a responsive menu that behaves differently depending on the browser width.

<Slide disableEsc />

Overlay

You can turn off the default overlay with noOverlay.

<Slide noOverlay />

Burger Icon and Cross Icon

You can disable both icons by passing burgerIcon and crossIcon to false. This can be useful if you want to keep the menu open and don't want the user to close the menu

<Slide :burgerIcon="false" :crossIcon="false"/>

Styling

Visual styles (color, font etc) need to be supplied with the help of CSS

CSS

The component has following helper class

 .bm-burger-button {
      position: fixed;
      width: 36px;
      height: 30px;
      left: 36px;
      top: 36px;
      cursor: pointer;
    }
    .bm-burger-bars {
      background-color: #373a47;
    }
    .line-style {
      position: absolute;
      height: 20%;
      left: 0;
      right: 0;
    }
    .cross-style {
      position: absolute;
      top: 12px;
      right: 2px;
      cursor: pointer;
    }
    .bm-cross {
      background: #bdc3c7;
    }
    .bm-cross-button {
      height: 24px;
      width: 24px;
    }
    .bm-menu {
      height: 100%; /* 100% Full-height */
      width: 0; /* 0 width - change this with JavaScript */
      position: fixed; /* Stay in place */
      z-index: 1000; /* Stay on top */
      top: 0;
      left: 0;
      background-color: rgb(63, 63, 65); /* Black*/
      overflow-x: hidden; /* Disable horizontal scroll */
      padding-top: 60px; /* Place content 60px from the top */
      transition: 0.5s; /*0.5 second transition effect to slide in the sidenav*/
    }

    .bm-overlay {
      background: rgba(0, 0, 0, 0.3);
    }
    .bm-item-list {
      color: #b8b7ad;
      margin-left: 10%;
      font-size: 20px;
    }
    .bm-item-list > * {
      display: flex;
      text-decoration: none;
      padding: 0.7em;
    }
    .bm-item-list > * > span {
      margin-left: 10px;
      font-weight: 700;
      color: white;
    }

Browser Support

Chrome and Firefox have full support, but Safari and IE have strange behavior for some of the menus.

Author

ยฉ Mohit Bajoria

License

MIT

Like it ? it

vue-burger-menu's People

Watchers

James Cloos avatar  avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.