如何使用 jQuery 动态禁用下拉框中与输入框内容相同的选项

13次阅读

如何使用 jQuery 动态禁用下拉框中与输入框内容相同的选项

本文介绍如何通过 jquery 监听输入框事件,实时比对用户输入内容与下拉菜单选项文本,并自动禁用匹配项,实现输入即禁用的交互效果。

在表单开发中,常需避免用户在输入框和下拉框中重复选择相同值(例如“New”既手动输入又从下拉中选中),此时可借助 jquery 实现动态禁用逻辑:当用户在输入框中键入某文本(如 NEW),下拉框中对应文本的

✅ 实现原理

核心思路是监听输入框的 keyup(实时响应键盘输入)和 change(兼容粘贴、失焦等场景)事件,获取当前输入值,再遍历下拉框所有

? 完整示例代码

    
$('.typeVal').on('keyup change', function() {   const inputText = $(this).val().trim(); // 去除首尾空格,提升健壮性   $('#select2 option').prop('disabled', function() {     return $(this).text().trim() === inputText;   }); });

⚠️ 注意事项

  • 大小写敏感:上述代码默认区分大小写(”New” ≠ “new”)。如需忽略大小写,可改为:
    return $(this).text().trim().toLowerCase() === inputText.toLowerCase();
  • 空值处理:trim() 可避免因空格导致误判;若输入为空,所有选项将恢复启用(因比对结果全为 false)。
  • 性能考虑:对于超大选项列表(如数百项),建议添加防抖(debounce)逻辑,避免高频触发。
  • 无障碍支持:禁用选项后,屏幕阅读器会跳过该

✅ 效果验证

  • 输入 New →被禁用(置灰且不可选);
  • 输入 OLD → 第二项被禁用;
  • 清空输入框 → 所有选项自动恢复可用。

该方案轻量、可复用,适用于多组输入+下拉联动场景,只需统一类名(.typeVal)与下拉 ID(#select2)即可快速集成。

text=ZqhQzanResources