input[type="color"]需严格满足格式、事件和兼容性条件,否则降级为文本框;value必须是7位小写十六进制,须标准化校验;实时响应用input事件,提交用change事件;iOS Safari 15.4+才原生支持,旧版需降级;不可自定义弹窗样式,无障碍需补充aria-label。
input[type="color"] 能用,但必须严格满足格式、事件和兼容性三方面条件,否则默认变黑、不触发、或直接降级为文本框。
浏览器对 value 格式极其敏感:写成 "red"、"rgb(255,107,53)"、"#f08"、"#ff6b3580"(带 alpha)或空字符串,都会静默回退为 "#000000"。
#abc → #aabbcc),再转小写localStorage 或 API 读取后,校验 value.length === 7 && value[0] === '#',不满足就 fallback 到默认色v-model 或 value 时,初始值不能是 undefined 或 null,否则首次渲染即失败用户在拾色器中拖拽滑块、旋转色环时,change 事件完全不触发——它只在点击“确定”或失焦后发生一次。需要实时反馈(比如预览色块、同步到其他输入框)必须用 input。
el.addEventListener('input', e => console.log(e.target.value)):每次变动立即执行el.addEventListener('change', e => saveColor(e.target.value)):适合提交前最终取值oninput 或 onchange 属性写法,容易被后续 JS 覆盖iOS Safari 15.4+ 才真正支持 type="color";15.4 前及 IE 完全不识别,会当普通 text 渲染,且不触发任何相关事件。
立即学习“前端免费学习笔记(深入)”;
const isColorSupported = document.createElement('input').type === 'color';
input[type="text"],并加 pattern="#[0-9a-fA-F]{6}" 和 JS 校验appearance: none 或覆盖 ::-webkit-color-swatch 过度,也可能导致拾色器无法唤起input[type="color"] 的弹窗 UI 完全由系统控制,Chrome、Safari、Firefox 显示形态不同,且无法通过 CSS 修改布局、滑块、色环或透明度控件。
input[type="color"]::-webkit-color-swatch { border-radius: 4px; }
vanilla-picker 或 iro.js 等库aria-label、不支持键盘方向键调节 HSL 分量,会导致屏幕阅读器用户无法操作最易被忽略的点是:value 的标准化发生在浏览器内部,JS 拿到的永远是小写 7 位 hex,你不能也不该去解析它、转换它、或拿它和 rgb() 字符串直接比对——校验只做长度和首字符,其余全交给浏览器。