android侧滑菜单slid,移动端高仿APP侧滑导航控件Slideout.js

编程入门 行业动态 更新时间:2024-10-25 14:24:53

android侧滑菜单slid,移动端高仿APP侧滑导航<a href=https://www.elefans.com/category/jswz/34/1769529.html style=控件Slideout.js"/>

android侧滑菜单slid,移动端高仿APP侧滑导航控件Slideout.js

Slideout.js简介

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

查看Demo(在你的移动设备上或在你的浏览器上模拟触摸)

安装

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

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

$ npm install slideout

$ spm install slideout

$ bower install slideout.js

$ component install mango/slideout

如何使用

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

Menu

Panel

然后在你的 .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 并创建一个实例

var slideout = new Slideout({

'panel': document.getElementById('panel'),

'menu': document.getElementById('menu'),

'padding': 256,

'tolerance': 70

});

完整示例

Slideout Demo

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;

}

Menu

Panel

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

});

浏览器支持

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了

参考文档:.html

更多推荐

android侧滑菜单slid,移动端高仿APP侧滑导航控件Slideout.js

本文发布于:2024-02-11 20:33:11,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1683310.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:控件   菜单   slid   android   端高仿

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!