Material Design 中实现折叠式 NavigationDrawer

面试官:小伙子,你的代码为什么这么丝滑?

在 Material Design 中,NavigationDrawer 是一个非常重要的组件,它允许用户在应用程序中导航到不同的区域。为了更好地适应不同大小的屏幕,Google 在 Material Design 2.0 中引入了折叠式 NavigationDrawer,它在大屏幕上以常规抽屉样式显示,而在小屏幕上则会折叠成一个浮动操作按钮菜单。

在本文中,我们将讨论如何使用 Material Design 中的一些组件和 JavaScript 图像库来实现这种折叠式 NavigationDrawer。

效果演示

在开始之前,让我们先看一下最终实现的效果。

使用 Material Design 组件创建 NavigationDrawer

首先,我们需要使用 Material Design 组件来创建 NavigationDrawer。我们可以使用 material-components-web 库中的 drawer 组件来实现这一点。

---- ------ ---
------ ----------------- -------------------------
  ---- ----------------------------
    ---- -----------------
      -- --------------------- ---------
        ----- -------------------------------- --------
      ----
      -- --------------------- ---------
        ----- -------------------------------- --------
      ----
      -- --------------------- ---------
        ----- -------------------------------- --------
      ----
    ------
  ------
--------

---- ------ ------- ---
---- -------------------------------
  ------- ------------------------
    ---- -----------------------------
      -------- ------------------------------- ---------------------------------------
        ------- --------------------- -------------------------------- ------------------------------
        ----- ---------------------------------- ------------
      ----------
    ------
  ---------
  ----- --------------------------------------
    ---- ------- ---- ---- ---
  -------
------

在上面的代码中,我们创建了一个 aside 元素,并将其包含在一个 mdc-drawer 类中。 这使得我们可以使用 mdc-drawer--dismissible 类将侧栏抽屉变成可滑动的。

然后,我们在抽屉里添加了一些导航链接,这些链接将在单击时导航到不同的页面。 接下来,我们创建了一个 div 元素,将它包含在 mdc-drawer-app-content 类中,并在这个 div 元素内放置了一个 header、一个 main 和一个 footer。

实现折叠式 NavigationDrawer

现在,我们来看看如何将我们的抽屉转换为折叠式抽屉。为此,我们需要借用 Material Components Web 库中的 Top App Bar 组件。

首先,我们需要添加 Top App Bar 组件到 mdc-drawer-app-content 中。该组件应该包含一个导航图标按钮和应用程序标题。 我们可以使用 Material Icons 字体来显示导航按钮。

---- --- --- --- ---
------- ------------------------
  ---- -----------------------------
    -------- ------------------------------- ---------------------------------------
      ------- --------------------- -------------------------------- ------------------------------
      ----- ---------------------------------- ------------
    ----------
  ------
---------

接下来,我们需要编写一些 JavaScript 代码来处理点击导航图标按钮的事件,并展开或折叠 NavigationDrawer。

----- -------- - --------------------------------------
----- ----------- - -------------------------------------------
----- --------- - ---------------------------------------------------------------

----------------------------------- ----- -- -
  -----------------------
  ----------------------------------------------
---

上述代码首先从 DOM 中获取 mdc-drawer 成分,然后获取 mdc-top-app-bar 中导航图标按钮。 然后,当用户单击导航图标按钮时,我们切换 mdc-drawer 成分的 mdc-drawer--open 类以实现折叠式 NavigationDrawer 的展开和折叠。

实现自适应 NavigationDrawer

我们还需要确保我们的 NavigationDrawer 能够自适应各种屏幕大小和方向。为此,我们可以使用 MDI(Material Design Icons)图像库,使我们的浮动操作按钮菜单看起来像一个浮动按钮,而不是缩小的抽屉。

首先,我们需要在我们的 HTML 中添加 MDI 的 CSS 样式文件:

----- --------------------------------------------------------------------------------- -----------------

然后,我们可以使用 MDI 中的材料设计类来创建一个浮动操作按钮菜单:

---- -------- ------ ------ ---- ---
---- ------------------------
  -- -------------- ----------------- ------------------------ ----------------- ---------
    ----- -------------------- --------------------------
    ----- -------------------------- -----------
  ----
  ---- --------------- ---------------- ----------------------
    --- ---------------- ----------- ------------------ ----------------------------
      --- --------------------- --------------- ------------------- ------
      --- --------------------- --------------- ------------------- ------
      --- --------------------- --------------- ------------------- ------
    -----
  ------
------

请注意,我们在浮动操作按钮菜单中使用了两个 div 元素:一个包含 mdc-fab-wrapper 类,一个包含 mdc-fab mdc-fab--extended mdc-fab--shape--extended mdc-fab--primary 类。这使得我们的浮动操作按钮菜单看起来更像一个浮动按钮。

在上述代码中,我们添加了一个 nav 元素,将其包含在 mdc-menu mdc-menu-surface mdc-menu--quick-open 类中,以便在悬停菜单中添加一些选项。

接下来,我们需要在 JavaScript 中处理点击浮动按钮事件,并打开/关闭 MDI 菜单。

-- --- --- ------
----- ------------ - -------------------------------------------
----- ----- - ---------------------------------------
----- ------ - ----------------------------------------

------------------------------- -- -- -
  ----------- - -------------
---

上述代码中,我们从 DOM 中获取 mdc-fabmdc-menu 元素,并添加一个事件监听器来处理单击事件。在单击事件中,我们切换 mdc-menu 元素的 open 属性以打开或关闭浮动操作按钮菜单。

结论

在本文中,我们讨论了如何使用 Material Design 中的一些组件和 JavaScript 图像库来创建一个折叠式 NavigationDrawer。我们首先讨论了如何使用 Material Design 组件创建 NavigationDrawer,并在此基础上实现了折叠式 NavigationDrawer。接下来,我们使用 MDI 图像库创建了一个浮动操作按钮菜单,并在响应单击事件时打开/关闭菜单。

希望这篇文章能帮助你了解如何使用 Material Design 和 JavaScript 实现折叠式 NavigationDrawer。如果你有任何疑问或建议,欢迎在评论中与我们分享。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/6705ccc5d91dce0dc855051c


猜你喜欢

  • 如何避免 Tailwind CSS 样式冲突的问题?

    在前端开发中,为了减少 CSS 的编写量,提高样式的复用性,越来越多的开发者开始使用工具库来帮助自己快速编写样式。而 Tailwind CSS 就是其中一个非常受欢迎的工具库,其提供了丰富的类名,可以...

    10 天前
  • 使用 Express.js 实现 OAuth 认证

    OAuth 是一种常见的认证授权协议,用于保护 Web 应用程序中的数据和资源,为用户提供登录和授权的方式。在今天的 Web 应用程序中,OAuth 已经成为了一种必不可少的技术。

    10 天前
  • 在 ES10 中使用 try catch 的技巧

    在前端编程过程中,我们往往需要处理各种异常,以确保我们的代码能够正常运行。为了实现这个目标,我们可以使用 try catch 语句。在 ES10 中,我们可以使用一些技巧来更好地利用这个语句。

    10 天前
  • Web Components 如何在低时延、高吞吐率的环境下实现快速渲染?

    Web Components 是一项已经有一段时间的技术,它可以让前端开发者更加方便地复用和组合 UI 组件。然而,在低时延、高吞吐率的环境下,Web Components 的渲染速度可能会受到影响。

    10 天前
  • 解决 CSS Grid 在 Firefox 中出现的失效问题与兼容性问题

    CSS Grid 布局是一种相当强大的网格布局系统,可以帮助前端开发人员更方便地实现复杂的布局。然而,在 Firefox 浏览器中,CSS Grid 可能会遇到失效问题和兼容性问题。

    10 天前
  • ES6 语法糖:解析箭头函数的各种用法

    在现代前端开发中,JavaScript 语言越发地被广泛应用。ES6 是 JavaScript 语言的一个重要版本,其中的箭头函数(Arrow Functions)被称为语法糖,用途广泛且易学易用。

    10 天前
  • Redis 应用:图像处理任务调度实现

    Redis 是一个内存中的数据结构存储系统,广泛应用于各种领域中,其中包括任务调度。在本文中,我们将介绍如何使用 Redis 实现图像处理任务的调度,并提供示例代码。

    10 天前
  • Fastify 安全指南:使用 fastify-helmet-plus 插件更好的保护应用

    随着网络安全问题的日益严重,前端应用程序的安全性也变得越来越重要。Fastify 是一个快速和低开销的 Node.js web 框架,它具有许多内置的安全机制来保护应用。

    10 天前
  • Node.js 中使用 Throng 进行进程管理

    Node.js 中使用 Throng 进行进程管理 在现代 web 应用开发中,Node.js 作为一种优秀的后端开发语言受到广泛的欢迎。Node.js 提供了很好的性能和可扩展性,但是在处理高流量网...

    10 天前
  • 在使用 LESS 编写样式时,如何统一文本字号

    LESS是一种CSS预处理器,可以让我们编写更加易于维护和复用的样式。在使用LESS编写样式时,如何统一文本字号是一个非常重要的问题。本文将介绍如何使用LESS来统一文本字号,包括实际使用中的示例代码...

    10 天前
  • Serverless 如何处理函数重用

    随着云计算的发展,Serverless 逐渐成为前端领域中的热门技术之一。Serverless 的核心概念是函数计算,通过把应用程序拆分成小型无状态函数,可以更灵活地处理负载,提高计算效率,降低成本和...

    10 天前
  • 如何解决在 Cypress 测试框架中访问 DOM 元素失败的问题?

    如何解决在 Cypress 测试框架中访问 DOM 元素失败的问题? 在前端开发中,测试是一个非常重要的环节。Cypress 是一款功能强大的前端自动化测试框架,可用于构建端到端(end-to-end...

    10 天前
  • 如何使用 Jest 进行前端测试

    前端测试是确保我们的网站或应用能够正常工作的最佳方法之一。在这个领域,Jest 可能是最流行的工具。Jest 是一个由 Facebook 开源的 JavaScript 测试框架,它提供了简单的 API...

    10 天前
  • 无障碍设计在电商平台中的营销实践

    随着电子商务的迅猛发展,越来越多的人选择在网上购买商品。但是,对于一些身体上有障碍的用户,访问电商平台并不容易。这时,无障碍设计就派上了用场。本文将介绍无障碍设计在电商平台中的营销实践,以及如何为所有...

    10 天前
  • Hapi.js 教程:如何使用 Catbox-Redis 插件缓存 Node.js 数据

    如果你正在做 Node.js 开发,并且正在寻找一种优化性能的方法,那么缓存数据是一个不错的选择。当你的应用在高流量情况下仍然需要快速响应请求时,缓存是一种快速而且有用的方法。

    10 天前
  • 如何遵循 Web Components 的最佳实践?

    Web Components 是一种很有前途的技术,它可以让我们将一个页面分解为更小的、可重用的部分,从而使得页面更加灵活和易于维护。但是,要写出高质量的 Web Components 并不容易,本文...

    10 天前
  • Mongoose 解决 MongoDB 中 Duplicate Key 错误

    前言 如果你常常使用 MongoDB 作为数据库,那么你一定会遇到一些常见的错误,其中一个就是 "duplicate key error",这个错误会阻止你在数据库中插入一条已经存在的记录。

    10 天前
  • Ubuntu18.04 Docker镜像标签更新失败的解决方法

    在使用Docker时,我们常常需要更新Ubuntu18.04镜像标签,以获得最新的功能和安全修复。然而,在更新时可能会出现失败的情况,本文将提供一个解决方案。 问题描述 问题可以表现为,在执行以下命令...

    10 天前
  • Redis 运维手册:性能评测和监控建议

    Redis 是一个流行的内存数据存储系统,广泛应用于互联网应用程序中。但是,Redis 的性能和稳定性对于大规模的生产环境来说至关重要。因此,为了使您的 Redis 集群正常工作,需要进行正确的性能评...

    10 天前
  • 响应式设计中如何实现 REM 适配

    在现代 Web 开发中,响应式设计已经成为了一种普遍的技术选择,因为响应式设计能够兼容各种不同尺寸和分辨率的设备,以及适应用户设备的不同旋转方向。而在实现响应式设计时, REM 适配是一种比较实用的技...

    10 天前

相关推荐

    暂无文章