bootstrap-validator校验行为不触发的解决

       今天在测试的时候遇到一个诡异的问题,画面上有一个输入框,点击输入框弹出一个模态框,在模态框中选择相应的值然后赋值到输入框中,但是当第一次触发非空异常校验时,再次选择一个值填进去后,仍然显示异常校验信息并且校验不通过。后来经过和小伙伴的探讨,发现虽然我们在点击保存按钮时调用的isValid方法,但是每一个控件的校验时间并不是点击保存按钮时,而是在我们改变输入框内容的时候,所以我们又模拟了change事件,发现不好用,接下来我们又尝试了keyup、keydown等事件,仍然是无效,最后发现bootstrap-validator每一个控件的校验调用的居然是input事件,而我居然没有听过这个事件,长见识了,解决方案如下(赋值后模拟input事件):

txtDept.trigger('input');

顺便我们也调研了这个优秀的事件,发现事情并不是那么简单的:

oninput 事件在用户输入时触发。

该事件在 <input> 或 <textarea> 元素的值发生改变时触发。

提示: 该事件类似于 onchange 事件。不同之处在于 oninput 事件在元素值发生变化是立即触发, onchange 在元素失去焦点时触发。另外一点不同是 onchange 事件也可以作用于 <keygen> 和 <select> 元素。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值