当前位置: 首页 > news >正文

闭坑-- `a-auto-complete` 组件中的 `options` 数据存在重复

ant-designa-auto-complete 组件中的 options 数据存在重复时,可能会导致以下问题:


在这里插入图片描述

1. 交互问题

  • 键盘导航失效
    使用键盘上下键选择时,可能会在重复项之间跳转,无法正常移动到下一个选项。
  • 选择结果不准确
    选择重复项时,可能无法正确触发 @select 事件,或返回错误的值。

2. 数据绑定问题

  • 表单值混乱
    如果重复的 value 绑定到表单字段(如 v-model),可能导致表单提交错误的数据。
  • 选项匹配错误
    组件内部通过 value 匹配选项时,可能选中第一个匹配项而非用户实际选择的项。

3. 性能问题

  • 冗余渲染
    重复数据会导致不必要的 DOM 渲染,降低性能(尤其在长列表中)。

4. 用户体验问题

  • 视觉干扰
    重复选项会让用户困惑,降低信任感。
  • 搜索建议无效
    输入时弹出的建议列表出现重复项,干扰用户决策。

问题复现场景

假设接口返回以下重复数据:

options.value = [{ label: '123', value: '公司A' }, { label: '123', value: '公司A' } // 重复项
];

用户操作时:

  1. 输入关键词搜索,下拉列表显示两个相同的“公司A”。
  2. 用键盘选择第二个“公司A”时,可能实际选中第一个。
  3. 提交表单时,可能传递错误的数据(如 label 重复导致税号错误)。

解决方案

1. 数据去重

在赋值 options 前,对接口返回的数据去重:

// 方法1: 使用 Set 去重 (根据唯一键如 label+value)
const uniqueData = Array.from(new Set(data.map(item => JSON.stringify({ label: item.comCode, value: item.comName })))
).map(str => JSON.parse(str));// 方法2: 使用 lodash 的 uniqBy (按特定字段去重)
import { uniqBy } from 'lodash';
options.value = uniqBy(data, 'comCode');
2. 防抖优化请求

避免频繁触发接口导致数据重复加载:

import { debounce } from 'lodash';const getOptions = debounce(async (value) => {if (!value) return;const { data } = await queryOptions({ searchName: value });options.value = uniqBy(data, 'comCode');
}, 300); // 300ms防抖
3. 检查组件配置
  • 确保 a-auto-completefilterOption 逻辑正确:
    <a-auto-complete:filterOption="(inputValue, option) => option.value.toLowerCase().includes(inputValue.toLowerCase())"
    />
    
  • 如果使用远程搜索 (@search),避免在 @change 中重复触发请求。
4. 后端配合

确保接口返回的数据本身去重,减少前端处理成本。


总结

问题类型后果解决方案
交互异常键盘导航/选择失效数据去重 + 防抖
数据绑定错误表单提交错误值确保 value 唯一性
性能下降渲染卡顿减少重复数据
用户体验差用户困惑/不信任显示唯一且清晰的选项

通过数据去重和优化请求逻辑,可以彻底解决重复项问题。

相关文章:

  • STM32 F103 标准库CH452A 4线 数码管驱动芯片显示数码管
  • LVS+Keepalived+dns高可用项目架构
  • Obsidian无门槛简明教程
  • 写项目时一些疑惑:组件间的通信、createDownloadUrl和DownloadUrl,ArrayBuffer与Blob等
  • C++十进制与十六进制
  • 20个常用的初级Java笔试题及其参考答案
  • 这几天调试VR,几个渲染效果不错
  • 【随身WIFI】随身WiFi Debian系统优化教程
  • Sql刷题日志(day3)
  • Vue基础(5)_事件修饰符
  • 软件工程知识体系全面梳理
  • libevent的各个基本函数的使用
  • STM32+dht11+rc522+jq8400的简单使用
  • Minecraft盔甲机制详解(1.9之后)
  • 文件的加密与解密学习笔记
  • MIR-2025 | 多模态知识助力机器人导航:从复杂环境到高效路径规划
  • 2025年4月16日华为笔试第三题300分
  • 数据结构与算法-顺序表专题
  • 【裁员感想】
  • 禁用USB接口的电脑管理软件推荐
  • 广东雷州农商行董事长、原行长同日被查
  • 中国纪检监察报刊文:要让劳动最光荣成为社会的崇高风尚
  • 十四届全国人大常委会第十五次会议在京举行,审议民营经济促进法草案等
  • 榆林市委常委王华胜已任榆林市政协党组书记
  • 谁将主导“视觉大脑”?中国AI的下一个超级赛道
  • 钟声:美以芬太尼为借口滥施关税,纯属“内病外治”