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

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

本文旨在指导开发者如何实现一个基于前端的选项过滤功能。我们将通过一个学校信息展示的示例,详细讲解如何使用 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): 用于动态生成并展示学校信息卡片。

3. JavaScript 逻辑的编写

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

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

3.1 生成学校信息卡片

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

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 或其他优化技术,提高页面渲染性能。用户体验: 可以添加过渡效果,使过滤过程更加平滑。

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1517696.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 10:56:47
下一篇 2025年12月20日 10:56:55

相关推荐

  • 如何利用Web Components技术创建可复用的自定义HTML元素?

    Web Components 通过自定义元素、影子 DOM 和 HTML 模板实现可复用、封装良好的独立组件。1. 使用 customElements.define() 注册带连字符的自定义标签;2. 类继承 HTMLElement 定义行为;3. 在构造函数中用 this.attachShadow…

    好文分享 2025年12月20日
    000
  • 在动态生成的HTML表格中实现星级评分

    本文档旨在解决在动态生成的HTML表格中实现星级评分时遇到的问题,重点讲解如何确保每个表格行中的星级评分组件独立工作,互不影响。通过修改HTML元素的id和name属性,使每个评分组件具有唯一标识符,从而实现独立评分功能。 问题分析 在动态生成的HTML表格中,如果每个表格行中的星级评分组件的 id…

    2025年12月20日
    000
  • 在Node.js中访问和修改CSS规则:JSDOM与CSS AST解析

    在node.js环境中处理css规则不同于浏览器dom操作。本文将介绍两种主要方法:一是利用jsdom模拟浏览器环境,实现对`document.stylesheets`等dom api的访问;二是采用csstree库进行css抽象语法树(ast)解析,实现对css内容的深度分析、转换与生成。这两种方…

    2025年12月20日
    000
  • 如何在客户端安全地创建 Stripe Payment Link

    本文探讨了在纯静态网站环境下,如何在不暴露 Stripe Secret Key 的前提下,动态生成 Stripe Payment Link 的问题。由于 Stripe API 的安全机制限制,直接在客户端创建 Payment Link 存在安全风险。本文提供了两种替代方案:预先生成固定 Paymen…

    2025年12月20日
    000
  • 如何在HTML文件中添加图片(Flask应用)

    本文旨在指导开发者如何在Flask框架下,正确地在HTML文件中嵌入本地图片。通过调整项目目录结构,并使用正确的路径引用方式,确保图片能够成功显示在网页上。本文将提供详细步骤和示例代码,助你解决图片显示问题。 在使用Flask框架开发Web应用时,经常需要在HTML页面中展示图片。如果图片文件位于本…

    2025年12月20日 好文分享
    000
  • Web组件开发与Shadow DOM深入

    Shadow DOM是Web组件中实现样式与结构封装的核心技术,通过attachShadow方法为元素挂载独立的影子树,形成隔离的DOM作用域,确保内部样式和结构不被外部影响,同时支持slot机制实现内容分发,提供开放(open)和封闭(closed)两种模式以控制访问权限,其中open模式允许通过…

    2025年12月20日
    000
  • 服务端渲染原理与同构应用开发

    服务端渲染(SSR)通过在服务器生成完整HTML提升首屏速度与SEO,同构架构使代码可在服务端与客户端共享;其流程包括路由匹配、组件渲染、HTML生成与状态注入,浏览器接收后即时展示并由客户端框架“激活”交互;关键挑战在于规避浏览器API、生命周期差异、数据预取同步及样式处理,Next.js、Nux…

    2025年12月20日
    000
  • 函数式编程库Lodash源码解析

    Lodash通过模块化架构、惰性求值机制提升性能,支持函数重载、柯里化与偏应用,结合类型判断与缓存优化,实现高效灵活的工具库设计。 Lodash 是一个一致性、模块化、高性能的 JavaScript 实用工具库,提供了大量对数组、对象、字符串等数据类型的便捷操作方法。其源码设计精巧,充分体现了函数式…

    2025年12月20日
    000
  • 如何通过JavaScript实现高级的浏览器存储方案?

    答案:现代Web开发需结合IndexedDB、统一接口、安全控制与Service Worker实现高效存储。首先使用IndexedDB处理大规模结构化数据,支持事务与索引;其次封装兼容IndexedDB、localStorage及内存的统一存储层,确保降级可用;再通过加密、过期机制和CSP增强安全性…

    2025年12月20日
    000
  • React应用中Swiper组件本地图片路径处理指南

    本教程详细探讨了在react应用中使用swiper组件时,本地背景图片无法正确显示的问题。核心原因在于react项目对静态资源路径的处理机制。文章阐述了如何将图片放置在`public`文件夹中,并通过相对路径或`process.env.public_url`环境变量正确引用这些图片,从而确保swip…

    2025年12月20日 好文分享
    000
  • 优化 AdSense 插页式广告的显示:理解与遵守政策

    adsense 插页式广告旨在自动优化显示时机,通常在页面导航时触发。尝试通过自定义脚本强制或修改其显示行为,例如在用户首次访问时强制弹出,是违反adsense政策的,可能导致账户被禁用。正确的做法是依赖adsense的自动广告功能,确保合规性并维护用户体验。 理解 AdSense 插页式广告的运作…

    2025年12月20日
    000
  • React UI组件设计模式:如何优雅地处理元素变体

    在react中管理ui组件(如按钮、链接)的不同变体是常见的挑战。本文探讨了两种主要策略:构建一个能够处理所有逻辑的“智能组件”,以及更推荐的基于“基础组件”和组合的模式。我们将详细阐述如何通过创建可复用的基础组件,并利用组合来构建特定用途的变体,从而实现更清晰、更易维护和更具扩展性的组件架构。 引…

    2025年12月20日
    000
  • Google 饼图数据格式化:如何在切片值中显示百分比符号

    本文将详细介绍如何在 google 饼图的切片值和工具提示中正确显示百分比符号。通过利用 google charts 提供的 google.visualization.numberformat 类,开发者可以精确控制数值的显示格式,避免直接在后端数据库查询中进行字符串拼接,从而确保图表的正确渲染和数…

    2025年12月20日
    000
  • 优化 Google 饼图:为切片值添加百分比符号的专业指南

    本教程旨在指导开发者如何在 google 饼图的切片值旁精确地添加百分比符号,从而提升数据可视化效果。文章首先分析了直接在后端进行字符串拼接的局限性,并推荐采用 google charts 内置的 `google.visualization.numberformat` 类进行数据格式化。通过详细的代…

    2025年12月20日
    000
  • Cypress中正确处理元素数量检查与操作:.then()回调与测试设计优化

    本文旨在解决Cypress测试中,如何在`.then()`回调内正确获取jQuery对象的子元素数量,并根据此数量执行后续操作。文章将详细阐述jQuery对象与原生DOM元素属性的区别,提供正确的子元素获取方法,并强调在Cypress测试中避免使用`if-else`条件逻辑的最佳实践,建议通过设置明…

    2025年12月20日
    000
  • 如何使用React Router实现条件式详情页导航

    在构建单页应用时,我们经常会遇到这样的场景:一个导航菜单项指向一个资源列表页(例如 `/persons`),该页面会展示所有可用资源。用户通常可以从列表中选择一个项目,跳转到其详情页(例如 `/persons/:personid`)。然而,当资源列表恰好只包含一个项目时,为了优化用户体验,我们可能希…

    2025年12月20日
    000
  • 将一组数字规范化到0-1范围的实用指南

    本文详细介绍了如何将一组数字规范化到一个0到1的范围,其中集合中的最大值映射为1,最小值(通常为0)映射为0。通过将每个数字除以集合中的最大值来实现这一目标,这对于根据数值大小动态调整css不透明度等场景非常有用,提供了清晰的javascript代码示例和实现步骤。 理解0-1范围规范化 在数据处理…

    2025年12月20日
    000
  • 获取 nipple.js 虚拟摇杆数据:位置、距离与方向

    本文详细介绍了如何使用 nipple.js 库获取虚拟摇杆的实时位置、距离和方向数据。通过监听摇杆的“move”事件,开发者可以轻松提取摇杆中心、摇杆手柄位置以及移动距离和角度等关键信息,克服了官方文档缺乏实践示例的难题,为游戏或交互式应用开发提供了清晰的实现指导。 理解 nipple.js 的数据…

    2025年12月20日
    000
  • 利用 jQuery 和 this 关键字实现输入字段的实时货币格式化

    本教程详细介绍了如何使用 jquery 和 javascript 的 intl.numberformat api,为具有特定 css 类(如 currency)的多个输入字段实现实时货币格式化功能。通过监听 keyup 事件并巧妙运用 this 关键字,确保用户在任意输入框键入时,系统能精确地格式化…

    2025年12月20日
    000
  • Cypress测试:获取子元素数量与验证动态内容更新的最佳实践

    本教程探讨了在cypress中正确获取dom元素子节点数量的方法,特别是在`cy.then()`回调中处理jquery对象。我们将详细介绍如何使用jquery的`.children()`方法或原生dom属性来获取子元素数量,并强调在测试动态内容增长时,应避免在单个测试中使用`if-else`逻辑,提…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信