曾经在表单交互开发中,我遇到过一个不大不小的陷阱:本想根据输入长度动态控制“下一步”按钮的启用与禁用,结果却总是无法实时生效。检查后发现,根源在于选错了监听事件。本文将分享这个经验,并提供一个可直接复用的完整代码示例。
在日常前端开发中,表单交互有一个非常普遍的需求:用户输入达到指定长度(例如至少6个字符)后,提交按钮才从禁用状态切换为可用状态。许多人第一反应会选用 change 事件,但这里存在一个容易忽视的细节——change 事件只有在输入框失去焦点且值发生变化时才会被触发。换句话说,即使你在输入框内敲了半天键盘,只要没有点击页面其他位置,按钮状态就不会更新。这显然无法满足实时反馈的需求。
更合理的做法是监听 input 事件。这个事件会在用户每次输入内容发生改变时立即触发,无论是键盘逐字键入、粘贴内容还是删除字符,都能同步更新按钮状态。它真正实现了“每一次输入,立即响应”的实时交互效果。
下面提供一个完整、健壮且可直接复制运行的实现示例:
动态按钮控制示例
