这个原生多选下拉组件,在默认情况下,用户必须按住 Ctrl(Mac 上为 ⌘)或 Shift 键才能连续选中多个选项——这与大多数用户直觉上“点一下即选中,再点即取消”的操作习惯完全不符。要让点击行为直接切换选中状态、无需任何修饰键,就必须依靠 Ja vaScript 来接管其交互逻辑。

如何让 真正支持多选操作
默认情况下, 仅仅开启了多选界面,但用户仍需配合修饰键才能完成多选——这与现代交互预期差距很大。要实现类似复选框的行为,关键在于以下几点:
- 必须监听
click事件,而不是change。因为change事件在元素失去焦点时才触发,无法实时响应用户的单次点击。 - 每次点击时,需要手动读取
event.target.selectedOptions,或者遍历options数组来判定selected状态。 - 注意:直接对
option.selected赋值会引发重排,如果操作频繁,建议先批量修改再统一提交。
为什么 select[multiple] 的 value 属性只返回第一个选中项
的 value 属性是只读的,DOM 规范明确规定了它始终返回第一个被选中的 的 value 值——即使你选中了十个选项,它也只会返回第一个。这不是 bug,而是标准行为。
- 若要获取全部选中值,请使用
Array.from(select.selectedOptions).map(opt => opt.value)。 - 如果
没有设置value属性,那么它的值就是textContent,需留意空格和换行可能混入。 - 服务端接收时,后端接口必须支持数组类型(例如
name=tags[]或 JSON body),否则将只能收到一个字符串。
移动端 Safari 中 multiple 的兼容性陷阱
iOS Safari 对原生 的支持堪称灾难:点击后弹出一个单选式的全屏选择器,甚至不显示已选项的状态,用户根本无法确认多选结果。
- 在 iOS 上,
multiple实际上不可用。建议检测na vigator.userAgent.includes('iPhone')或使用@supports (-webkit-appearance: none)进行降级处理。 - 推荐方案:用
+模拟多选,配合 ARIA 属性(aria-selected、aria-multiselectable)确保可访问性。 - 如果实在要用原生
select,至少加上size="5"让选项立即可见,避免单纯下拉触发 Safari 的错误弹窗。
提交表单时,multiple 选中的数据怎么被后端正确解析
浏览器提交时, 会将每个选中项作为独立字段发送,例如 colors=red&colors=blue&colors=green。但不同后端框架的处理方式差异较大。
- PHP 默认将同名参数覆盖为最后一个值(
$_GET['colors']只能得到green),必须使用colors[]=red&colors[]=blue格式,即name="colors[]"。 - Node.js 的
urlencoded中间件(如 express.urlencoded)默认支持数组,但需设置extended: true。 - 如果走 AJAX 提交,更稳妥的做法是手动序列化:
new FormData(form).getAll('colors')或JSON.stringify(selectedValues)。
实际开发中,最常被忽视的就是 iOS 行为和后端参数命名约定——前者导致线上用户投诉“点不动”,后者导致后端收不到完整数组。别指望浏览器自动帮你做对。
