在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
开源软件名称(OpenSource Name):Mango/slideout开源软件地址(OpenSource Url):https://github.com/Mango/slideout开源编程语言(OpenSource Language):JavaScript 50.5%开源软件介绍(OpenSource Introduction):Slideout.js
Features
DemoCheck out the demo to see it in action (on your mobile or emulate touches on your browser). InstallationSlideout is available on cdnjs <script src="https://cdnjs.cloudflare.com/ajax/libs/slideout/1.0.1/slideout.min.js"></script> Also you can use one of many package managers
UsageImplementing Slideout.js into your project is easy. First of all, you'll need to create your markup. You should have a menu ( <nav id="menu">
<header>
<h2>Menu</h2>
</header>
</nav>
<main id="panel">
<header>
<h2>Panel</h2>
</header>
</main> Add the Slideout.js styles (index.css) in your web application. body {
width: 100%;
height: 100%;
}
.slideout-menu {
position: fixed;
top: 0;
bottom: 0;
width: 256px;
min-height: 100vh;
overflow-y: scroll;
-webkit-overflow-scrolling: touch;
z-index: 0;
display: none;
}
.slideout-menu-left {
left: 0;
}
.slideout-menu-right {
right: 0;
}
.slideout-panel {
position: relative;
z-index: 1;
will-change: transform;
background-color: #FFF; /* A background-color is required */
min-height: 100vh;
}
.slideout-open,
.slideout-open body,
.slideout-open .slideout-panel {
overflow: hidden;
}
.slideout-open .slideout-menu {
display: block;
} Then you just include Slideout.js, create a new instance with some options and call the toggle method: <script src="dist/slideout.min.js"></script>
<script>
var slideout = new Slideout({
'panel': document.getElementById('panel'),
'menu': document.getElementById('menu'),
'padding': 256,
'tolerance': 70
});
// Toggle button
document.querySelector('.toggle-button').addEventListener('click', function() {
slideout.toggle();
});
</script> Full example<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Slideout Demo</title>
<meta http-equiv="cleartype" content="on">
<meta name="MobileOptimized" content="320">
<meta name="HandheldFriendly" content="True">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
<style>
body {
width: 100%;
height: 100%;
}
.slideout-menu {
position: fixed;
left: 0;
top: 0;
bottom: 0;
right: 0;
z-index: 0;
width: 256px;
overflow-y: scroll;
-webkit-overflow-scrolling: touch;
display: none;
}
.slideout-panel {
position: relative;
z-index: 1;
will-change: transform;
}
.slideout-open,
.slideout-open body,
.slideout-open .slideout-panel {
overflow: hidden;
}
.slideout-open .slideout-menu {
display: block;
}
</style>
</head>
<body>
<nav id="menu">
<h2>Menu</h2>
</nav>
<main id="panel">
<header>
<button class="toggle-button">☰</button>
<h2>Panel</h2>
</header>
</main>
<script src="dist/slideout.min.js"></script>
<script>
var slideout = new Slideout({
'panel': document.getElementById('panel'),
'menu': document.getElementById('menu'),
'padding': 256,
'tolerance': 70
});
// Toggle button
document.querySelector('.toggle-button').addEventListener('click', function() {
slideout.toggle();
});
</script>
</body>
</html> Browser Support
APISlideout(options)Create a new instance of
var slideout = new Slideout({
'panel': document.getElementById('main'),
'menu': document.getElementById('menu'),
'padding': 256,
'tolerance': 70,
'easing': 'cubic-bezier(.32,2,.55,.27)'
}); Slideout.open();Opens the slideout menu. It emits slideout.open(); Slideout.close();Closes the slideout menu. It emits slideout.close(); Slideout.toggle();Toggles (open/close) the slideout menu. slideout.toggle(); Slideout.isOpen();Returns slideout.isOpen(); // true or false Slideout.destroy();Cleans up the instance so another slideout can be created on the same area. slideout.destroy(); Slideout.enableTouch();Enables opening the slideout via touch events. slideout.enableTouch(); Slideout.disableTouch();Disables opening the slideout via touch events. slideout.disableTouch(); Slideout.on(event, listener);slideout.on('open', function() { ... }); Slideout.once(event, listener);slideout.once('open', function() { ... }); Slideout.off(event, listener);slideout.off('open', listener); Slideout.emit(event, ...data);slideout.emit('open'); EventsAn instance of Slideout emits the following events:
The slideout emits slideout.on('translatestart', function() {
console.log('Start');
});
slideout.on('translate', function(translated) {
console.log('Translate: ' + translated); // 120 in px
});
slideout.on('translateend', function() {
console.log('End');
});
// 'Start'
// 'Translate 120'
// 'End'
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论