用 Slideout.js 开发移动 Web 应用导航栏菜单

作者: WenryXu | 来源:发表于2015-10-14 11:11 被阅读2713次

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

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

安装

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

<script src="https://cdnjs.cloudflare.com/ajax/libs/slideout/0.1.9/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;
}

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

      .slideout-panel {
        position:relative;
        z-index: 1;
      }

      .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>

浏览器支持

  • 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 从左侧或右侧打开 (leftright)。默认:left
var slideout = new Slideout({
  'panel': document.getElementById('main'),
  'menu': document.getElementById('menu'),
  'padding': 256,
  'tolerance': 70
});

Slideout.open();

打开 slideout 菜单。触发 beforeopenopen 事件。

slideout.open();

Slideout.close();

关闭 slideout 菜单。触发 beforecloseclose 事件。

slideout.close();

Slideout.toggle();

打开/关闭 slideout 菜单。

slideout.toggle();

Slideout.isOpen();

当 slideout 处于打开状态时返回 true,当处于关闭状态时返回 false

slideout.isOpen(); // true or 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 实例可以触发以下事件:

  • beforeclose
  • close
  • beforeopen
  • open
  • translate

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

slideout.on('translate', function(translated) {
  console.log(translated); // 120 in px
});

FAQ

如何添加一个切换按钮

// vanilla js
document.querySelector('.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'
});

相关文章

  • 用 Slideout.js 开发移动 Web 应用导航栏菜单

    Slideout.js 是一个 Web 上的可触控的导航栏菜单。 查看 Demo(在你的移动设备上或在你的浏览器上...

  • 顶部菜单和左右侧菜单在网页程序中的实现

    在Web应用开发过程中,导航菜单的实现一直是必不可少的。通常菜单的表现形式上用两种:顶部菜单和左右侧菜单。不管是顶...

  • Mac如何移动隐藏删除顶部菜单栏图标

    教你如何移动隐藏删除mac菜单栏图标 苹果菜单栏贯穿 Mac 的屏幕顶部。 左侧是苹果菜单和应用菜单,应用菜单一般...

  • 新贵 Flutter (10)侧拉抽屉菜单

    在移动开发中,我们可以通过底部导航栏、标签页或是侧边抽屉菜单来实现导航。这是在小屏幕上可以充分利用空间。我们设计不...

  • SystemUI之快捷面板的修改

    SystemUI简介 作为系统应用,SystemUI 包含的内容较多,比如状态栏、通知栏、下拉菜单、导航栏、锁屏、...

  • 工具栏菜单

      Android5.0引入了工具栏这个新增组件。在此之前,应用中用于导航或提供菜单操作的是操作栏。  工具栏菜单...

  • 移动应用UI设计模式图示

    移动应用UI设计模式: 1.导航设计模式:主要导航和次要导航模式。 1)主菜单导航模式: 跳板式 Springbo...

  • Web页面嵌入到Qt注意事项

    目前,web页面嵌入Qt框架方式: Qt:系统、一级、二级菜单框架;底部消息栏。 Web:三级菜单子页面。 开发方...

  • Web前端-JavaScript基础教程上

    Web前端-JavaScript基础教程 将放入菜单栏中,便于阅读! JavaScript是web前端开发的编程语...

  • 1.3 界面元素

    打开MisShop设计器,可以看到MisShop平台开发界面元素的分布有 菜单栏、视图按钮区、工具按钮区、导航栏、...

网友评论

    本文标题:用 Slideout.js 开发移动 Web 应用导航栏菜单

    本文链接:https://www.haomeiwen.com/subject/tzvocttx.html