JavaScript input输入数值(value)无效的原因和解决办法
会碰到这个问题一般是想×别人的网页导致的,一般来说想控制别人写的网页(或者维护一份别人的网页代码)碰到需要用JS给input或者select之类的组件赋值的时候一般会直接这样写:
let casess=document.getElementsByClassName('xxxxx')[0]; casess.value='50';
赋值后点击有时候会报错有时候不会,一般报错的情况基本上属于这份代码用了某些前端框架,例如Vue之类的,Vue的input弄个双向绑定啥的,此时我们用原生的JS企图去控制输入框的值就会出现无效的情况(明明input上有数字或者字符但是点击按钮就是说你没填内容)。因为此时只是修改了value属性,没有触发input或change事件,导致输入没有最终确定。input和change事件默认情况下(作者设计的时候),只有当接收到键盘的按键(随便哪个键盘的按键消息),就会触发input和change事件,进而把输入框中的value赋值给预设的相关变量,到这一步才算走完整个设置value的过程。所以如果想给这类加料的输入框或者选择框用原生JS赋值,设置vlaue属性过后就必须手动触发一下input或change事件。下面是例子:
input的例子:
let casess=document.getElementsByClassName('input_amo')[0]; //input_amo -- 是input的类 casess.value='50'; var event = document.createEvent('HTMLEvents'); event.initEvent("input", true, true); var eve3nt = document.createEvent('HTMLEvents'); eve3nt.initEvent("blur", true, true); event.eventType = 'message'; casess.dispatchEvent(event); casess.dispatchEvent(eve3nt);
如果是select选择框把"input"改成"change"即可,更多信息请看参考资料。
参考资料:https://blog.csdn.net/russle/article/details/67637500
转载自:https://blog.csdn.net/l198738655/article/details/107026783/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
2019-12-24 WPF中用户控件对比自定义控件(UserControl VS CustomControl)