返回

边栏可伸缩折叠菜单+页面滚动时固定顶部【Sass高级技巧+响应式自适应效果】

前端

前言
本文将创建一个具有边栏可伸缩折叠菜单、页面滚动时自动固定顶部功能的布局。为了展示不同宽度情况下的样式变化,分别以El-table和普通html代码方式实现表格布局。

Sass 使用步骤

  1. 安装Node.js 和 NPM:
    • 在命令行中输入以下命令:
      node -v
      npm -v
      
    • 如果没有安装,请按照官方文档进行安装。
  2. 创建Sass项目:
    • 在项目目录中,使用以下命令创建 package.json 文件:
      npm init -y
      
    • 然后在 package.json 文件中添加以下代码:
      {
          "name": "sass-project",
          "version": "1.0.0",
          "description": "Sass project",
          "scripts": {
              "start": "node-sass --watch sass:css"
          },
          "dependencies": {
              "node-sass": "^4.13.1"
          }
      }
      
  3. 安装Sass:
    • 使用以下命令安装 Sass:
      npm install node-sass --save-dev
      
  4. 创建Sass 文件:
    • 在项目目录中创建一个名为 sass 的文件夹,并在其中创建一个名为 style.scss 的文件。
  5. 编写 Sass 代码:
    • 在 style.scss 文件中,编写 Sass 代码。

构建可伸缩边栏菜单

/* 侧边栏样式 */
.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: 250px;
  height: 100vh;
  background-color: #222;
  transition: width 0.3s ease-in-out;

  /* 菜单折叠时的样式 */
  &.collapsed {
    width: 70px;
  }

  /* 菜单展开时的样式 */
  &.expanded {
    width: 250px;
  }
}

/* 菜单栏样式 */
.menu {
  list-style-type: none;
  padding: 0;
  margin: 0;

  /* 菜单项样式 */
  li {
    padding: 10px;
    color: #fff;
    cursor: pointer;

    /* 菜单项悬停时的样式 */
    &:hover {
      background-color: #333;
    }

    /* 菜单项激活时的样式 */
    &.active {
      background-color: #444;
    }
  }
}

实现页面滚动时固定顶部

/* 头部样式 */
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 60px;
  background-color: #fff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

代码实例

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  
  <link rel="stylesheet" href="style.css">
</head>
<body>

  <div class="sidebar">
    <ul class="menu">
      <li class="active">首页</li>
      <li>关于我们</li>
      <li>产品</li>
      <li>联系我们</li>
    </ul>
  </div>

  <div class="content">
    <h1>标题</h1>
    <p>正文</p>
  </div>

  <script>
    // 菜单折叠展开功能
    const sidebar = document.querySelector('.sidebar');
    const menu = document.querySelector('.menu');

    menu.addEventListener('click', (e) => {
      sidebar.classList.toggle('collapsed');
    });

    // 页面滚动时固定顶部功能
    window.addEventListener('scroll', () => {
      const header = document.querySelector('.header');

      if (window.pageYOffset > 0) {
        header.classList.add('fixed');
      } else {
        header.classList.remove('fixed');
      }
    });
  </script>
</body>
</html>

效果预览
运行代码后,您将看到一个具有边栏可伸缩折叠菜单和页面滚动时自动固定顶部的布局。您可以通过点击菜单项来折叠和展开侧边栏,也可以通过滚动页面来固定顶部。