0

0

JS如何实现搜索过滤_JavaScript列表搜索与实时过滤方法详解

星夢妙者

星夢妙者

发布时间:2025-11-03 14:38:02

|

153人浏览过

|

来源于php中文网

原创

首先构建HTML结构,包含搜索框和列表;然后通过JavaScript获取元素并监听输入事件,实时过滤列表项;接着优化体验,支持忽略大小写、部分匹配、清空恢复及防抖处理;最后扩展为动态渲染模式,利用数组filter和map方法实现灵活数据过滤。该方案适用于多种前端场景。

js如何实现搜索过滤_javascript列表搜索与实时过滤方法详解

在网页开发中,实现一个实时搜索过滤功能非常常见,比如用户输入关键词时,列表会自动筛选出匹配的项。JavaScript 能轻松实现这一交互效果,无需刷新页面即可动态更新内容。下面详细介绍如何用原生 JavaScript 实现列表的搜索与实时过滤。

1. 基本HTML结构

先构建一个简单的列表和搜索框,作为操作目标:


  • 苹果
  • 香蕉
  • 橙子
  • 葡萄
  • 草莓

2. 获取元素并绑定事件

使用 document.getElementById 获取搜索框和列表元素,并监听输入事件(input)来实现实时响应:

const searchInput = document.getElementById('searchInput');
const itemList = document.getElementById('itemList');
const listItems = itemList.getElementsByTagName('li');

searchInput.addEventListener('input', function() {
  const keyword = searchInput.value.toLowerCase();

  for (let i = 0; i < listItems.length; i++) {
    const item = listItems[i];
    const text = item.textContent.toLowerCase();

    if (text.includes(keyword)) {
      item.style.display = '';
    } else {
      item.style.display = 'none';
    }
  }
});

这段代码的核心逻辑是:当用户输入内容时,遍历所有列表项,检查其文本是否包含搜索关键词。如果包含,显示该项;否则隐藏。

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

知识画家
知识画家

AI交互知识生成引擎,一句话生成知识视频、动画和应用

下载

3. 提升用户体验的小技巧

为了让搜索更友好,可以加入以下优化:

  • 忽略大小写:将输入和文本都转为小写进行比较,避免因大小写导致漏匹配。
  • 支持部分匹配:使用 includes() 方法实现模糊搜索,比如搜“葡”也能匹配“葡萄”。
  • 空输入时恢复全部:当搜索框清空,所有项自动显示。
  • 防抖处理(可选):对于大型列表,可添加简单防抖避免频繁触发:
let timer;
searchInput.addEventListener('input', function() {
  clearTimeout(timer);
  timer = setTimeout(() => {
    // 执行过滤逻辑
  }, 150);
});

4. 扩展:支持更多数据类型

如果列表是通过 JavaScript 动态生成的(如从数组渲染),可以结合 map 和 filter 方法重构逻辑:

const fruits = ['苹果', '香蕉', '橙子', '葡萄', '草莓'];

function renderList(items) {
  itemList.innerHTML = items.map(name =>
    `
  • ${name}
  • ` ).join(''); } searchInput.addEventListener('input', () => { const filtered = fruits.filter(fruit => fruit.toLowerCase().includes(searchInput.value.toLowerCase()) ); renderList(filtered); }); // 初始渲染 renderList(fruits);

    这种方式更灵活,适合与后端数据结合使用。

    基本上就这些。用原生 JavaScript 实现搜索过滤不复杂,关键是监听输入、遍历比对、控制显示。掌握这个模式后,可以轻松应用到表格、卡片、下拉选项等场景中。

    热门AI工具

    更多
    DeepSeek
    DeepSeek

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

    豆包大模型
    豆包大模型

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

    通义千问
    通义千问

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

    腾讯元宝
    腾讯元宝

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

    文心一言
    文心一言

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

    讯飞写作
    讯飞写作

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

    即梦AI
    即梦AI

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

    ChatGPT
    ChatGPT

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

    相关专题

    更多
    数据类型有哪几种
    数据类型有哪几种

    数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    309

    2023.10.31

    php数据类型
    php数据类型

    本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

    222

    2025.10.31

    golang map内存释放
    golang map内存释放

    本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

    75

    2025.09.05

    golang map相关教程
    golang map相关教程

    本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

    36

    2025.11.16

    golang map原理
    golang map原理

    本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

    61

    2025.11.17

    java判断map相关教程
    java判断map相关教程

    本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

    42

    2025.11.27

    js正则表达式
    js正则表达式

    php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

    515

    2023.06.20

    js获取当前时间
    js获取当前时间

    JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

    244

    2023.07.28

    C++ 设计模式与软件架构
    C++ 设计模式与软件架构

    本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

    9

    2026.01.30

    热门下载

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

    精品课程

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

    共185课时 | 21.5万人学习

    SQL 教程
    SQL 教程

    共61课时 | 3.6万人学习

    C++教程
    C++教程

    共115课时 | 14.8万人学习

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

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