×About ×About
首页CMS教程WordPress创建响应式设计滑动侧导航菜单

创建响应式设计滑动侧导航菜单

在本教程中,您将使用 JavaScript 和 CSS 创建可扩展的侧面导航菜单。最终产品如下图所示:

1. 创建标记

首先,让我们为侧边菜单添加一些标记:

<div id="sideNavigation" class="sidenav">
  <a href="#" class="close-btn">&times;</a>
  <a href="#">About</a>
  <a href="#">Features</a>
  <a href="#">Contact Us</a>
</div>
 
<nav class="topnav">
  <a href="#" class="ham-icon">
    <svg width="30" height="30" id="icoOpen">
        <path d="M0,5 30,5" stroke="#000" stroke-width="5"/>
        <path d="M0,14 30,14" stroke="#000" stroke-width="5"/>
        <path d="M0,23 30,23" stroke="#000" stroke-width="5"/>
    </svg>
  </a>
</nav>
 
<section id="main">
  <h1 id="This-Side-Navigation-Menu-Looks-Good">This Side Navigation Menu Looks Good!</h1>
  <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
</section>

在这里你可以看到我们用类 sidenav 创建了一个侧边菜单 div 。接下来,我们通过 <nav></nav> 标签添加了实际的顶部栏导航,并且我们使用 SVG 作为侧面菜单图标。

记住将网站的所有内容放入 div id="main" 容器中,以便它向右滑动。

2. 编写 JavaScript 代码

接下来,让我们添加 JavaScript,该 JavaScript 将使用 ham-icon 类侦听汉堡包图标上的单击事件,以及侧面导航菜单滑到屏幕上后出现的关闭按钮。

document.querySelector("a.ham-icon").addEventListener("click", function(event){
  document.getElementById("sideNavigation").style.width = "250px";
  document.getElementById("main").style.marginLeft = "250px";
});

document.querySelector("a.close-btn").addEventListener("click", function(event){
  document.getElementById("sideNavigation").style.width = "0";
  document.getElementById("main").style.marginLeft = "0";
});

单击汉堡包图标应该会显示侧面导航。为此,我们将导航的宽度设置为 250px,同时向主要网站内容添加 250px 的左边距。

单击关闭按钮应该会隐藏侧面导航。为此,我们将导航的宽度更改回 0,同时将主网站内容的左边距设置为 0。

3. 使用 CSS 样式

最后,我们需要使用一些 CSS 来设置侧边菜单和链接的页面样式。 CSS 会将所有网页元素正确放置在我们想要的位置。我们还将在 transition 属性的帮助下应用一些简单的动画。让我们一次看一下 CSS 的一部分。

.sidenav {
  height: 100%;
  width: 0;
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  background-color: #111;
  overflow-x: hidden;
  padding-top: 4rem;
  transition: 0.4s cubic-bezier(0.18, 0.89, 0.32, 1.28);
  font-family: "Bebas Neue";
}

.sidenav a {
  padding: 0.5rem 1rem;
  text-decoration: none;
  color: #bdbdbd;
  display: block;
  transition: 0.4s;
  white-space: nowrap;
  font-size: 2rem;
}

.sidenav a:hover {
  color: white;
  background: #9e9e9e;
}

我们将侧边导航的height设置为100%,并将其初始width设置为0以使其隐藏。但是,只有当 overflow-x 属性的值设置为 hidden 时,侧边导航的内容才会保持隐藏。

过渡属性可确保侧面导航宽度的变化不会突然发生,并且缓动功能使其具有一点弹性。

对于侧面导航内的链接,我们将 white-space 属性的值设置为 nowrap ,以便菜单文本不会溢出多行。

.sidenav .close-btn {
  position: absolute;
  top: -1rem;
  right: 1rem;
  font-size: 5rem;
}

.sidenav .close-btn:hover {
  background: initial;
  transform: scale(1.2);
}

上面的 CSS 样式将我们的关闭按钮与侧面导航中的其他链接分开。我们对关闭按钮应用了绝对定位,并防止其背景在悬停时变成浅灰色。当用户将鼠标悬停在其上方时,它的大小还会放大 20%。

现在,以下 CSS 将通过使用相同的过渡持续时间和相同的缓动函数来确保主要内容位置的移动与导航菜单同步。将 overflow-x 属性的值设置为 hidden 可确保不会因内容移动而出现水平滚动条。

#main {
  transition: margin-left 0.4s cubic-bezier(0.18, 0.89, 0.32, 1.28);
  padding: 20px;
  width: 100%;
}

body {
 overflow-x: hidden; 
}

我们还可以借助以下 CSS 为汉堡包图标添加一点旋转运动。它在 0.5 秒的时间内将汉堡包图标旋转 180 度。

a svg {
  transition: all 0.5s ease;
}
a svg:hover {
  transform: rotate(180deg);
}

最后,让我们通过使用以下 CSS 调整链接的间距和大小来使导航菜单具有响应能力。它确保菜单不会在垂直空间较小的屏幕上超出范围。

@media screen and (max-height: 480px) {
  .sidenav {
    padding-top: 3rem;
  }
  .sidenav a {
    font-size: 1.5rem;
  }
}

此时您的导航菜单应该类似于以下 CodePen 演示。

4. 移除幻灯片

要使菜单显示时没有幻灯片动画,只需更改 CSS 属性 transition,如下面的缩写形式所示:

.sidenav {
    transition: 0s; 
}

#main {
    transition: margin-left 0s;
}

这将使更改立即出现,因为 transition 中没有指定延迟。我们使用的默认值是 0.5s 中没有指定延迟。我们使用的默认值是 0.5s

结论

创建侧边菜单只需要几行代码,不需要使用很多资源。使代码能够响应不同的设备屏幕分辨率,只需通过针对特定情况添加媒体查询来修改 CSS。

为了更进一步,您可能希望使用 Bootstrap 或 Bulma 等 CSS 框架来设计菜单样式。

本文已根据 Monty Shokeen 的贡献进行了更新。 Monty 是一位全栈开发人员,他也喜欢编写教程和学习新的 JavaScript 库。

以上是创建响应式设计滑动侧导航菜单的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何轻松地将博客从 WordPress.com 移至 WordPress.org如何轻松地将博客从 WordPress.com 移至 WordPress.orgApr 18, 2025 am 11:33 AM

您想将博客从 WordPress.com 移至 WordPress.org 吗? 许多初学者从 WordPress.com 开始,但很快意识到其局限性,并希望切换到自托管 WordPress.org 平台。 在本分步指南中,我们将向您展示如何正确地将博客从 WordPress.com 移动到 WordPress.org。 为什么从 WordPress.com 迁移到 WordPress.org? WordPress.com 允许任何人通过创建帐户来

如何使用 IFTTT 自动化 WordPress 和社交媒体(及更多)如何使用 IFTTT 自动化 WordPress 和社交媒体(及更多)Apr 18, 2025 am 11:27 AM

您是否正在寻找自动化 WordPress 网站和社交媒体帐户的方法? 通过自动化,您将能够在 Facebook、Twitter、LinkedIn、Instagram 等平台上自动分享您的 WordPress 博客文章或更新。 在本文中,我们将向您展示如何使用 IFTTT、Zapier 和 Uncanny Automator 轻松实现 WordPress 和社交媒体的自动化。 为什么要自动化 WordPress 和社交媒体? 自动化您的WordPre

如何修复 WordPress 中的自定义菜单项限制如何修复 WordPress 中的自定义菜单项限制Apr 18, 2025 am 11:18 AM

就在几天前,我们的一位用户报告了一个不寻常的问题。问题是他达到了自定义菜单项的限制。达到菜单项限制后他保存的任何内容都将根本无法保存。我们从未听说过这个问题,因此我们决定在本地安装上尝试一下。创建了 200 多个菜单项并保存。效果很好。将 100 个项目移至下拉列表中,保存效果非常好。那时我们就知道这与服务器有关。经过进一步研究,似乎还有许多其他人也遇到了同样的问题。深入挖掘后,我们发现了一张 trac 票证 ( #14134 ) 强调了这个问题。在阅读了非常

如何在 WordPress 中将自定义元字段添加到自定义分类法如何在 WordPress 中将自定义元字段添加到自定义分类法Apr 18, 2025 am 11:11 AM

您需要将自定义元字段添加到 WordPress 中的自定义分类法吗? 自定义分类法可让您组织除类别和标签之外的内容。有时添加其他字段来描述它们很有用。 在本文中,我们将向您展示如何将其他元字段添加到他们创建的分类法中。 何时应将自定义元字段添加到自定义分类法? 当您在WordPress 网站上创建新内容时,您可以使用两种默认分类法(类别和标签)对其进行组织。 一些网站受益于自定义分类法的使用。这些允许您以其他方式对内容进行排序。 例如,

如何使用 Windows Live Writer 远程发布到 WordPress如何使用 Windows Live Writer 远程发布到 WordPressApr 18, 2025 am 11:02 AM

Windows live writer 是一款多功能工具,可让您直接从桌面将帖子发布到 WordPress 博客上。这意味着您根本不需要登录 WordPress 管理面板来更新您的博客。在本教程中,我将向您展示如何使用 Windows Live Writer 为您的 WordPress 博客启用桌面发布。 如何在 WordPress 上设置 Windows Live Writer 第 1 步: 要通过 Windows Live Writer 在 WordPr

如何修复 WordPress 可视化编辑器中的白色文本和缺失按钮如何修复 WordPress 可视化编辑器中的白色文本和缺失按钮Apr 18, 2025 am 10:52 AM

最近,我们的一位用户报告了一个非常奇怪的安装问题。写帖子时,他们看不到自己写的任何内容。因为帖子编辑器的文字是白色的。更重要的是,所有可视化编辑器按钮都丢失了,并且从可视化切换到 HTML 的功能也不起作用。在本文中,我们将向您展示如何修复 WordPress 可视化编辑器中的白色文本和缺失按钮问题。 初学者注意事项:如果您正在寻找可能在其他网站的屏幕截图中看到的隐藏按钮,那么您可能正在寻找厨房水槽。您必须单击厨房水槽图标才能看到其他选项,例如下划线、从单词复制等。

如何在 WordPress 中显示用户电子邮件中的头像如何在 WordPress 中显示用户电子邮件中的头像Apr 18, 2025 am 10:51 AM

您想在 WordPress 中显示用户电子邮件中的头像吗? Gravatar 是一项将用户的电子邮件地址连接到在线头像的网络服务。WordPress 会自动在评论部分显示访问者的头像,但您可能也想将它们添加到网站的其他区域。 在本文中,我们将向您展示如何在 WordPress 中显示用户电子邮件中的头像。 什么是 Gravatar 以及为什么要显示它? Gravatar代表全球认可的头像,它允许人们将图片链接到他们的电子邮件地址。 如果网站支

如何更改 WordPress 中的默认媒体上传位置如何更改 WordPress 中的默认媒体上传位置Apr 18, 2025 am 10:47 AM

您想更改 WordPress 中的默认媒体上传位置吗? 将媒体文件移动到其他文件夹可以提高网站的速度和性能,并帮助您更快地创建备份。它还使您可以自由地以最适合您的方式组织文件。 在本文中,我们将向您展示如何更改 WordPress 中的默认媒体上传位置。 为什么要更改默认媒体上传位置? 默认情况下,WordPress 将所有图像和其他媒体文件存储在 /wp-content/uploads/ 文件夹中。 在此文件夹中,您将找到不同年份和月份的子

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器