html页面 事件监听,HTML的input监听输入事件

$("#term").bind('input propertychange', function () {

var term = $("#term").val();

if (!type.test(term)) {

$("#message").html(" ဆ 输入有误,请输入正整数");

$("#addActive").addClass("layui-btn-disabled");

return false;

}

else {

$("#addActive").removeClass("layui-btn-disabled");

$("#message").html("  输入正确");

}

});

当输入框的值发生变化时,我们可以通过keydown、keyup、input、onchange、blur事件观察到其值的变化,但它们的应用时机与应用场景存在显著的差异。

1. 实时观察

需要观察到用户每次键盘输入的变化,必须要用keydown、keyup与input,onchange与blur无效。在这其中,keyup与input都能及时获取到用户输入的全值,而keydown不会将当前的键值计入到输入框的值中,示例如下:

//  假定页面存在如下元素

//

//  注册input事件

username.addEventListener("input", function(event) {

result.push({

event  : 'input',

value  : this.value,

keyCode : event.keyCode

});

})

//  注册keydown事件

username.addEventListener("keydown", function(event) {

result.push({

event  : 'keydown',

value  : this.value,

keyCode : event.keyCode

});

});

//  注册keyup事件

username.addEventListener("keyup", function(event) {

result.push({

event  : 'keyup',

value  : this.value,

keyCode : event.keyCode

});

});

//  注册change事件

username.addEventListener("change", function(event) {

result.push({

event  : 'change',

value  : this.value,

keyCode : event.keyCode

});

//  输出结果

console.table(result);

});

//  注册blur事件

username.addEventListener("blur", function(event) {

result.push({

event  : 'blur',

value  : this.value,

keyCode : event.keyCode

});

//  输出结果

console.table(result);

})12345678910111213141516171819202122232425262728293031323334353637383940414243444546

聚焦到输入框中,依次输入“abc”,最后控制台的输出结果如下图所示。

从图中可以看出如下结论:

1.  keydown事件发生时,输入值并没有发生变化,所以keydown可用于阻止某些输入字符的显示。

2.  input事件发生时,无法获取到keyCode值,并且紧随在keydown事件之后。

3.  keyup事件最后发生,一次键盘敲入事件彻底完成。

4.  change事件只会发生在输入完成后,也就是输入框失去焦点之前。

2. 输入完成后观察

当用户完成所有的输入时,这时候必定会发生blur事件,只有这时才会触发change,所以可用blur与change监听用户输入是否完成,输入框的验证多半发生在此时。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值