蓝戒博客

  • 首页
  • 研发说
  • 架构论
  • 效能录
  • AI谈
  • 随笔集
智构苍穹
AI为翼,架构为骨,文化为魂,实践探新境,价值筑长青。
  1. 首页
  2. 研发说
  3. 正文

移动端高仿APP侧滑导航控件Slideout.js

2016年5月12日 10062点热度 0人点赞 0条评论

Slideout.js简介

Slideout.js是一个Web上的可触控的导航栏菜单。

  • 查看Demo(在你的移动设备上或在你的浏览器上模拟触摸)
  • 下载Demo
  • Github地址

sildeout
安装

可以直接引入 cdnjs 上的 .js 文件:

<script src="https://cdnjs.cloudflare.com/ajax/libs/slideout/0.1.11/slideout.min.js"></script>

也可以使用包管理器安装:

$ npm install slideout

$ spm install slideout

$ bower install slideout.js

$ component install mango/slideout

如何使用

首先,你的菜单中需要有一个菜单(#menu)和主界面(#panel)

<nav id="menu">
<header>
<h2>Menu</h2>
</header>
</nav>

<main id="panel">
<header>
<h2>Panel</h2>
</header>
</main>

然后在你的 .css 文件中为 Slideout 添加样式

body {
width: 100%;
height: 100%;
}

.slideout-menu {
position: fixed;
left: 0;
top: 0;
bottom: 0;
right: 0;
z-index: 0;
width: 256px;
overflow-y: auto;
-webkit-overflow-scrolling: touch;
display: none;
}

.slideout-panel {
position:relative;
z-index: 1;
will-change: transfo rm;
}

.slideout-open,
.slideout-open body,
.slideout-open .slideout-panel {
overflow: hidden;
}

.slideout-open .slideout-menu {
display: block;
}

然后引入 Slideout.js 并创建一个实例

<script src="dist/slideout.min.js"></script>
<script>
var slideout = new Slideout({
'panel': document.getElementById('panel'),
'menu': document.getElementById('menu'),
'padding': 256,
'tolerance': 70
});
</script>

完整示例

<!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="viewpo rt" 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: auto;
-webkit-overflow-scrolling: touch;
display: none;
}

.slideout-panel {
position:relative;
z-index: 1;
will-change: transfo rm;
}

.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.querySelecto r('.toggle-button').addEventListener('click', function() {
slideout.toggle();
});
</script>

</body>
</html>

浏览器支持

  • Chrome(iOS、Android、PC)
  • Firefox(Android、PC)
  • Safari(iOS、Android、PC)
  • Opera(PC)
  • IE 10+(PC)

API

Slideout(options)

创建一个新的 Slideout 实例所要用到的选项

  • options (对象) - 一个使用自定义选项的 Slideout 实例。
  • options.panel (HTML 元素) - 程序中包含 .slideout-panel 的 DOM 元素。
  • options.menu (HTML 元素) - 程序中包含 .slideout-menu 的 DOM 元素。
  • [options.duration] (数字) - 打开/关闭 slideout 的时间(毫秒)。默认:300
  • [options.fx] (字符串) - 开启和关闭 slideout 时的 CSS 动画效果。默认:ease
  • [options.padding] (数字) - 默认:256
  • [options.tolerance] (数字) - 默认:70
  • [options.touch] (布尔值) - 设置此项为 false 可以禁用 Slideout 的触摸事件。默认:true
  • [options.side] (字符串) - 设置 slideout 从左侧或右侧打开 (left 或 right)。默认:left

var slideout = new Slideout({
'panel': document.getElementById('main'),
'menu': document.getElementById('menu'),
'padding': 256,
'tolerance': 70
});

Slideout.open();
打开 slideout 菜单。触发 befo reopen 和 open 事件。

slideout.open();

Slideout.close();
关闭 slideout 菜单。触发 befo reclose 和 close 事件。

slideout.close();

Slideout.toggle();
打开/关闭 slideout 菜单。

slideout.toggle();

Slideout.isOpen();
当 slideout 处于打开状态时返回 true,当处于关闭状态时返回 false。

slideout.isOpen(); // true o r false

Slideout.destroy();
清理其他的 slideout 实例使其可以在同一区域再次创建。

slideout.destroy();

Slideout.enableTouch();
开启通过触摸事件打开 slideout。

slideout.enableTouch();

Slideout.disableTouch();
禁止通过触摸事件打开 slideout。

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');

事件

一个 Slideout 实例可以触发以下事件:

  • befo reclose
  • close
  • befo reopen
  • open
  • translate

只有当通过触摸事件将它打开/关闭时,slideout 会触发 translate 事件。

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'

FAQ

如何添加一个切换按钮

// vanilla js
document.querySelecto r('.toggle-button').addEventListener('click', function() {
slideout.toggle();
});

// jQuery
$('.toggle-button').on('click', function() {
slideout.toggle();
});

如何从右侧打开 slideout

你应该为 .slideout-menu 类设置 left: auto。

.slideout-menu {
left: auto;
}

然后,设置 side 选项的值为 right。

var slideout = new Slideout({
'panel': document.getElementById('content'),
'menu': document.getElementById('menu'),
'side': 'right'
});

ps:系统拦截or字符,所有文中带有or的字符 中间加了空格or 写为o r了

参考文档:http://www.cocoachina.com/webapp/20151015/13776.html

标签: js库 侧滑导航
最后更新:2025年9月13日

cywcd

我始终相信,技术不仅是解决问题的工具,更是推动思维进化和创造价值的方式。从研发到架构,追求极致效能;在随笔中沉淀思考,于 AI 中对话未来。

打赏 点赞
< 上一篇
下一篇 >

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

cywcd

我始终相信,技术不仅是解决问题的工具,更是推动思维进化和创造价值的方式。从研发到架构,追求极致效能;在随笔中沉淀思考,于 AI 中对话未来。

最新 热点 随机
最新 热点 随机
Vue 3.6「无虚拟 DOM」时代开启:深入解读 Vapor Mode 的革命性变革 2025 最推荐的 uni-app 技术栈:unibest + uView Pro 高效开发全攻略 前端开源工具 PinMe:极简部署体验分享 架构评估方法 ATAM:系统性洞察架构质量的利器 软件系统架构评估与质量属性分析 AI 大模型开发:如何实现数据向量化
Webpack 实战:Code Splitting 优化页面加载性能前端开源工具 PinMe:极简部署体验分享AI 产品前端技术全解析:模型可视化与流式响应实践前端内存泄露防范及编码攻略DApp开发前端技术全解析:技术选型、功能实现与开发步骤Web Workers:释放浏览器多线程的魔力
js实现文字向上滚动,并且每滚动一行停顿几秒的效果 探索angularJS中的$watch,$apply,$digest理解双向数据绑定 Three.js 3D 可视化项目实战:从快速启动到性能优化全攻略 网页顶部页面加载线性进度条js及css3实现方法 打造企业级前端脚手架:基于 Plop.js 与 GitLab 远程配置的实战分享 前端模块构建工具webpack入门教程
最近评论
渔夫 发布于 6 天前(11月05日) 学到了,感谢博主分享
沙拉小王子 发布于 8 年前(11月30日) 适合vue入门者学习,赞一个
沙拉小王子 发布于 8 年前(11月30日) 适合vue入门者学习,赞一个
cywcd 发布于 9 年前(04月27日) 请参考一下这篇文章http://www.jianshu.com/p/fa4460e75cd8
cywcd 发布于 9 年前(04月27日) 请参考一下这篇文章http://www.jianshu.com/p/fa4460e75cd8

COPYRIGHT © 2025 蓝戒博客_智构苍穹-专注于大前端领域技术生态. ALL RIGHTS RESERVED.

京ICP备12026697号-2