0

0

JavaScript 中实现用户 ID 模糊搜索并动态渲染独立卡片

聖光之護

聖光之護

发布时间:2026-03-08 18:46:02

|

416人浏览过

|

来源于php中文网

原创

JavaScript 中实现用户 ID 模糊搜索并动态渲染独立卡片

本文详解如何使用原生 javascript 实现基于用户 id 的响应式模糊搜索功能,解决“结果全部挤在同一个 div 中”的常见问题,通过 filter() + map() 链式调用与 dom 重置策略,确保每次匹配项都渲染为独立的 .person 卡片,并适配 css grid 布局。

本文详解如何使用原生 javascript 实现基于用户 id 的响应式模糊搜索功能,解决“结果全部挤在同一个 div 中”的常见问题,通过 filter() + map() 链式调用与 dom 重置策略,确保每次匹配项都渲染为独立的 .person 卡片,并适配 css grid 布局。

在构建用户列表搜索功能时,一个典型误区是:在循环外部创建单个

元素,再反复向其注入 HTML 字符串——这会导致所有匹配结果被拼接进同一个 DOM 节点,丧失语义结构与样式隔离能力。正确做法是:为每个匹配项单独创建一个
,并统一插入容器;同时每次搜索前清空旧内容,避免重复叠加。

以下是优化后的完整实现方案:

✅ 核心改进点

  • 使用函数式编程思想:data.filter(...).map(...).join('') 生成结构化 HTML 字符串;
  • 每次执行 filter() 前调用 container.innerHTML = "" 彻底清空容器;
  • 为每个用户项生成带 class="person" 的独立
    ,便于后续样式控制与交互扩展;
  • 移除冗余的 appendChild(div) 操作,避免 DOM 插入逻辑混乱。
  • ? 完整可运行代码

    <!DOCTYPE html>
    <html lang="zh-CN">
    <head>
      <meta charset="UTF-8" />
      <title>ID 搜索示例</title>
      <style>
        html { font-size: 22px; }
        body { padding: 1rem; }
    
        #search {
          background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23999"><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"/></svg>');
          background-position: 5px 5px;
          background-repeat: no-repeat;
          font-size: 16px;
          padding: 12px 20px 12px 40px;
          border: 1px solid #ddd;
          margin-bottom: 12px;
          width: 100%;
          max-width: 400px;
        }
    
        button {
          font-size: 16px;
          padding: 12px 20px;
          border: 1px solid #ddd;
          margin-bottom: 12px;
          cursor: pointer;
        }
    
        .container {
          max-width: 1200px;
          margin: 0 auto;
          display: grid;
          gap: 1rem;
          grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
        }
    
        .container > div {
          background-color: dodgerblue;
          color: white;
          padding: 0.5rem;
          height: 10rem;
          border-radius: 4px;
          box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }
    
        .person p {
          margin: 4px 0;
          font-size: 0.9em;
        }
      </style>
    </head>
    <body>
    
    <input type="text" id="search" placeholder="Search by ID (e.g., '12')">
    <button onclick="filter()">Search</button>
    
    <div id="container" class="container"></div>
    
    <script>
    const data = [
      {Id: '123', Name: 'John Doe', Gender: 'Male'},
      {Id: '213', Name: 'Wilma Gil', Gender: 'Female'}, 
      {Id: '312', Name: 'Peter Lee', Gender: 'Male'},
      {Id: '421', Name: 'Chezka Ong', Gender: 'Female'}
    ];
    
    const inputField = document.getElementById("search");
    const container = document.getElementById("container");
    
    function filter() {
      const input = inputField.value.trim(); // 使用 trim() 过滤首尾空格
      container.innerHTML = ""; // ✅ 关键:每次搜索前清空容器
    
      if (!input) {
        console.log("Search input is empty");
        return;
      }
    
      // ✅ 链式处理:过滤 → 映射为 HTML → 合并为字符串
      const html = data
        .filter(user => user.Id.includes(input)) // 支持子串匹配(如 '12' 匹配 '123' 和 '312')
        .map(({ Id, Name, Gender }) => `
          <div class="person">
            <p><strong>ID:</strong> ${Id}</p>
            <p><strong>Name:</strong> ${Name}</p><div class="aritcle_card flexRow">
                                                            <div class="artcardd flexRow">
                                                                    <a class="aritcle_card_img" href="/ai/1433" title="Colossyan"><img
                                                                                    src="https://img.php.cn/upload/ai_manual/001/431/639/68b6cf81ded65811.png" alt="Colossyan"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                    <div class="aritcle_card_info flexColumn">
                                                                            <a href="/ai/1433" title="Colossyan">Colossyan</a>
                                                                            <p>AI虚拟人出镜视频生成</p>
                                                                    </div>
                                                                    <a href="/ai/1433" title="Colossyan" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                            </div>
                                                    </div><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/c1c2c2ed740f" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">Java免费学习笔记(深入)</a></a>”;</p>
            <p><strong>Gender:</strong> ${Gender}</p>
          </div>
        `)
        .join("");
    
      container.innerHTML = html;
    }
    </script>
    
    </body>
    </html>

    ⚠️ 注意事项与最佳实践

    • 不要在循环中复用同一 DOM 元素:原始代码中 div 在循环外创建,导致所有内容追加到一个节点。应为每个结果新建元素,或像本方案一样用字符串批量生成。
    • 始终清理旧 DOM:container.innerHTML = "" 是最简洁可靠的清空方式(比 removeChild() 更高效),但注意它会销毁绑定的事件监听器(本例无此需求)。
    • 增强健壮性:使用 .trim() 处理用户输入空白;用 !input 替代 input === null || input === '' 更安全。
    • 可扩展建议
      • 添加防抖(debounce)避免高频输入触发多次搜索;
      • 支持多字段搜索(如 Name 或 Gender);
      • 引入 textContent 替代插值防止 XSS(若数据不可信);
      • 将渲染逻辑抽离为独立函数,提升可测试性。

    该方案兼顾简洁性、可维护性与现代 Web 开发习惯,适用于中小型静态数据搜索场景,是原生 JavaScript 实现响应式列表过滤的推荐范式。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

253

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1069

2024.03.01

js 字符串转数组
js 字符串转数组

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

739

2023.08.03

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

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

220

2023.09.04

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

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

1563

2023.10.24

字符串介绍
字符串介绍

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

649

2023.11.24

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

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

1188

2024.03.22

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

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

1184

2024.04.29

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

59

2026.03.06

热门下载

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

精品课程

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

共58课时 | 5.9万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

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

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