Swipe Menu with Vanilla JS for mobile
npm install mobile-swipe-menu --save
new MobileSwipeMenu(selector, options)
Name | Type | Default | Description |
---|---|---|---|
mode |
string | right | operating mode (right, left) |
width |
number | 0 | menu width |
hookWidth |
number | 30 | protrusion width |
useHookWidthPercentage |
boolean | false | use percentage as hookWidth |
enableBodyHook |
boolean | false | react to the whole window |
events |
object | {} | event set object |
Name | Description |
---|---|
openMenu |
open the menu |
closeMenu |
close the menu |
toggleMenu |
open or close a menu |
disableSwipe |
disable menu swipe |
enableSwipe |
enable menu swipe |
Name | Description |
---|---|
start |
starting swiping menu |
stop |
stopping swiping menu |
opened |
menu is opened |
closed |
menu is closed |
drag |
the menu is swiping |
import MobileSwipeMenu from 'mobile-swipe-menu';
new MobileSwipeMenu('#menu', {
mode: 'right',
width: window.innerWidth / 1.15
});
<script src="js/mobile-swipe-menu.min.js"></script>
<script>
var mobileMenu = new MobileSwipeMenu('#menu', {
mode: 'right',
width: window.innerWidth / 1.15,
enableBodyHook: true,
events: {
opened: function () {
},
closed: function () {
},
drag: function (swipe) {
}
}
});
document.getElementById('openMenu').addEventListener('click', function () {
mobileMenu.openMenu();
});
document.getElementById('closeMenu').addEventListener('click', function () {
mobileMenu.closeMenu();
});
document.getElementById('toggleMenu').addEventListener('click', function () {
mobileMenu.toggleMenu();
});
</script>
This library will work with any front-end library.
The library will have to be transpiled using babel so add the following into the vue.config.js
module.exports = {
transpileDependencies: [
'mobile-swipe-menu'
]
};
in src folder add file: "mobile-swipe-menu.d.ts" with the following contents:
declare module 'mobile-swipe-menu';