0

0

如何实现博客文章卡片的动态分类筛选功能

霞舞

霞舞

发布时间:2026-02-09 11:44:21

|

867人浏览过

|

来源于php中文网

原创

如何实现博客文章卡片的动态分类筛选功能

本文详解基于原生 javascript 的博客卡片分类筛选功能实现,重点解决因 `data-category` 值不匹配导致的“全部显示”失效问题,并提供可直接运行的修复代码、结构优化建议与健壮性增强方案。

在构建响应式博客页面时,按类别(如「Digital Marketing」「Tips & Advice」「Cryptocurrency」)动态筛选内容卡片是常见需求。你已正确采用语义化 data-category 属性标记卡片与按钮,也使用了 DOMContentLoaded 事件确保 DOM 就绪,但筛选逻辑存在一个关键不一致点:过滤按钮中“All”项的 data-category="filter-all" 与 JavaScript 中硬编码的 'all' 字符串不匹配,导致点击“All”时无卡片显示。

✅ 正确的筛选逻辑修复

将判断条件中的 'all' 改为 'filter-all',使其与 HTML 中的属性值严格一致:

触站AI
触站AI

专业的中文版AI绘画生成平台

下载
document.addEventListener("DOMContentLoaded", () => {
  "use strict";

  const filterButtons = document.querySelectorAll('.blog-filters button');
  const articleCards = document.querySelectorAll('.article-card');

  filterButtons.forEach(button => {
    button.addEventListener('click', () => {
      const selectedCategory = button.getAttribute('data-category');

      articleCards.forEach(card => {
        const cardCategory = card.getAttribute('data-category');

        // ✅ 修复点:与 button 的 data-category 值保持一致
        if (selectedCategory === 'filter-all' || selectedCategory === cardCategory) {
          card.style.display = 'block';
        } else {
          card.style.display = 'none';
        }
      });
    });
  });
});
⚠️ 注意:原始代码末尾缺失闭合括号 });,已补全——这是语法错误,会导致脚本完全不执行。

? 进阶优化建议(提升健壮性与可维护性)

  1. 默认状态高亮当前激活按钮
    点击筛选后,建议为选中按钮添加 .active 类,便于用户识别当前视图:

    // 在 click 回调内添加(紧接在 forEach 之前)
    filterButtons.forEach(btn => btn.classList.remove('active'));
    button.classList.add('active');
  2. 支持空态提示(可选)
    当某类别无匹配卡片时,可显示友好提示:

    const visibleCount = Array.from(articleCards).filter(
      card => selectedCategory === 'filter-all' || 
             selectedCategory === card.getAttribute('data-category')
    ).length;
    
    if (visibleCount === 0 && selectedCategory !== 'filter-all') {
      document.querySelector('.posts-list').innerHTML = 
        '

    暂无该类别下的文章。

    '; }
  3. CSS 层级解耦(推荐)
    避免直接操作 style.display,改用 CSS 类控制显隐,更利于主题定制与动画:

    .article-card.hidden { display: none !important; }

    对应 JS 修改为:

    card.classList.toggle('hidden', 
      !(selectedCategory === 'filter-all' || selectedCategory === cardCategory)
    );

✅ 完整 HTML 结构验证要点

  • 所有 .article-card 元素必须包含 data-category,且值与按钮中完全一致(区分大小写与连字符);
  • “All”按钮必须使用 data-category="filter-all"(不可写作 "all" 或 "all-categories");
  • 确保

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

444

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

213

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1518

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

634

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

800

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

772

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

181

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

86

2025.08.07

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

98

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

CSS教程
CSS教程

共754课时 | 29.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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