首页 > web前端 > js教程 > 正文

实现前端页面选项过滤功能的教程

霞舞
发布: 2025-08-24 23:32:01
原创
186人浏览过

实现前端页面选项过滤功能的教程

本文旨在指导开发者如何实现一个基于前端的选项过滤功能。我们将通过一个学校信息展示的示例,详细讲解如何使用 JavaScript 和 CSS 来动态地显示和隐藏页面元素,从而实现按类别过滤学校的功能。本文将涵盖数据结构设计、HTML 结构搭建、JavaScript 逻辑编写以及 CSS 样式设置等方面,帮助读者快速掌握前端过滤功能的实现方法。

1. 数据结构的设计

首先,我们需要定义用于存储学校信息的数据结构。在这个例子中,我们使用一个 JavaScript 对象 schools,其中包含一个 data 数组。数组中的每个元素都是一个对象,代表一个学校,包含 schoolName(学校名称)、category(类别)和 image(图片链接)三个属性。

let schools = {
  data: [{
      schoolName: "Edmonton Catholic School District",
      category: "Catholic",
      image: "ecsd.png"
    },
    {
      schoolName: "Edmonton Public School",
      category: "Regular",
      image: "publicimg.jpg"
    },
    {
      schoolName: "Northern Alberta Institution of Technology",
      category: "College",
      image: "NAIT.png"
    },
    {
      schoolName: "University of Alberta",
      category: "University",
      image: "University-of-Alberta.png"
    },
  ],
};
登录后复制

2. HTML 结构的搭建

接下来,我们需要创建 HTML 结构来展示学校信息和过滤选项。主要包含以下几个部分:

  • 过滤按钮区域 (#buttons): 用于放置过滤选项按钮。
  • 学校展示区域 (#schools): 用于动态生成并展示学校信息卡片。
<div class="wrapper">
  <div id="buttons">
    <button class="button-value" onclick="filterSchool('all')">All</button>
    <button class="button-value" onclick="filterSchool('Catholic')">Catholic School</button>
    <button class="button-value" onclick="filterSchool('Regular')">Regular School</button>
    <button class="button-value" onclick="filterSchool('University')">University</button>
    <button class="button-value" onclick="filterSchool('College')">College</button>
  </div>
  <div id="schools"></div>
</div>
登录后复制

3. JavaScript 逻辑的编写

JavaScript 代码负责动态生成学校信息卡片,并实现过滤功能。

立即学习前端免费学习笔记(深入)”;

3.1 生成学校信息卡片

使用 for...of 循环遍历 schools.data 数组,为每个学校创建一个卡片元素,并将其添加到 #schools 区域。

 v1.1.6若依管理系统
v1.1.6若依管理系统

一直想做一款后台管理系统,看了很多优秀的开源项目但是发现没有合适自己的。于是利用空闲休息时间开始自己写一套后台系统。如此有了若依管理系统。她可以用于所有的Web应用程序,如网站管理后台,网站会员中心,CMS,CRM,OA。所有前端后台代码封装过后十分精简易上手,出错效率低。同时支持移动客户端访问。系统会陆续更新一些实用功能。 您是否在找一套合适后台管理系统。 您是否在找一套代码易读易懂后台

 v1.1.6若依管理系统 885
查看详情  v1.1.6若依管理系统
for (let i of schools.data) {
  // 创建卡片
  let card = document.createElement("div");
  // 添加卡片类别和隐藏类
  card.classList.add("card", i.category, "hide");

  // 创建图片容器
  let imgContainer = document.createElement("div");
  imgContainer.classList.add("image-container");

  // 创建图片元素
  let image = document.createElement("img");
  image.setAttribute("src", i.image);
  imgContainer.appendChild(image);
  card.appendChild(imgContainer);

  // 创建文本容器
  let container = document.createElement("div");
  container.classList.add("container");

  // 创建学校名称元素
  let name = document.createElement("h5");
  name.classList.add("school-name");
  name.innerText = i.schoolName.toUpperCase();
  container.appendChild(name);

  card.appendChild(container);
  document.getElementById("schools").appendChild(card);
}
登录后复制

3.2 实现过滤功能

filterSchool 函数接收一个 value 参数,表示要过滤的类别。该函数遍历所有卡片元素,根据卡片是否包含指定的类别,添加或移除 hide 类,从而实现显示和隐藏的效果。

function filterSchool(value) {
  let elements = document.querySelectorAll(".card");
  elements.forEach((element) => {
    if (value == "all") {
      element.classList.remove("hide");
    } else {
      if (element.classList.contains(value)) {
        element.classList.remove("hide");
      } else {
        element.classList.add("hide");
      }
    }
  });
}
登录后复制

3.3 页面加载完成时显示所有卡片

使用 window.onload 事件监听器,在页面加载完成后调用 filterSchool("all"),确保默认显示所有学校信息。

window.onload = () => {
  filterSchool("all");
}
登录后复制

4. CSS 样式的设置

CSS 样式用于美化页面,并实现隐藏效果。

  • .hide 类: 设置 display: none;,用于隐藏元素。这是实现过滤功能的核心。
.hide {
  display: none;
}
登录后复制
  • 其他样式用于美化页面,例如设置卡片布局、按钮样式等。
* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
  border: none;
  outline: none;
  font-family: 'Poppins', sans-serif;
}

body {
  background-color: white;
}

button {
  cursor: pointer;
}

.wrapper {
  position: absolute;
  top: 5%;
  left: 20%;
  width: 95%;
  margin: 0 auto;
}

.button-value {
  border: 2px solid black;
  padding: 0.5px 10px;
  border-radius: 3em;
  background-color: transparent;
  transition: 0.3s ease-in-out;
}

.button-value:focus {
  background-color: black;
  color: white;
}

#schools {
  display: grid;
  grid-template-columns: auto auto auto;
  grid-column-gap: 1.5em;
  padding: 2em 0;
}

.card {
  background-color: white;
  max-width: 18em;
  margin-top: 1em;
  padding: 1em;
  border-radius: 5px;
  box-shadow: 1em 2em 2.5em rgba(0, 0, 0, 0.19);
}

.image-container {
  text-align: center;
}

img {
  max-width: 100%;
  object-fit: contain;
  height: 15em;
}

.container {
  padding-top: 1em;
  color: black;
}

@media screen and (max-width: 720px) {
  img {
    max-width: 100%;
    object-fit: contain;
    height: 10em;
  }
  .card {
    max-width: 10em;
    margin-top: 1em;
  }
  #schools {
    grid-template-columns: auto auto;
    grid-column-gap: 1em;
  }
}
登录后复制

5. 总结与注意事项

  • CSS hide 类的定义至关重要: 缺少.hide { display: none; }会导致过滤功能失效。
  • 代码可维护性: 建议将 JavaScript 代码进行模块化,提高代码的可读性和可维护性。
  • 性能优化: 对于大量数据,可以考虑使用虚拟 DOM 或其他优化技术,提高页面渲染性能。
  • 用户体验: 可以添加过渡效果,使过滤过程更加平滑。

通过以上步骤,我们成功实现了一个基于前端的选项过滤功能。这个示例可以作为基础,根据实际需求进行扩展和修改,应用于各种不同的场景。

以上就是实现前端页面选项过滤功能的教程的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号