同时绑定onpropertychange 和 oninput 事件,实时检测 input、textarea输入改变事件,支持低版本IE,支持复制粘贴
2017-05-15 15:29
387 查看
实时检测 input、textarea输入改变事件,支持低版本IE,支持复制粘贴
检测input、textarea输入改变事件有以下几种:
1、onkeyup/onkeydown 捕获用户键盘输入事件。
缺陷:复制粘贴时无法检测
2、onchenge
缺陷:要满足触发条件:当前对象的属性改变(由键盘或鼠标触发)且对象失去焦点
3、onpropertychange 当前对象属性改变就会触发
缺陷:只支持低版本IE
4、oninput 和onpropertychange类似,当前对象属性改变就会触发
缺陷:不支持低版本IE
可以看出以上几种方法都有各自的缺陷,1和2一般不能满足需求,3和4的缺陷正好互补,两个事件结合起来使用可以兼容IE、firefox、chrome;
所以同时绑定[b]onpropertychange 和 [b][b]oninput 可以达到实时检测输入内容的目的[/b][/b][/b]
[b][b][b](jquery用[b][b]propertychange [b][b]和 [b][b]input[/b][/b][/b][/b][/b])。[/b][/b][/b][/b]
代码实例(jquery):
原文出处 superGG1990 www.cnblogs.com/superGG1990
检测input、textarea输入改变事件有以下几种:
1、onkeyup/onkeydown 捕获用户键盘输入事件。
缺陷:复制粘贴时无法检测
2、onchenge
缺陷:要满足触发条件:当前对象的属性改变(由键盘或鼠标触发)且对象失去焦点
3、onpropertychange 当前对象属性改变就会触发
缺陷:只支持低版本IE
4、oninput 和onpropertychange类似,当前对象属性改变就会触发
缺陷:不支持低版本IE
可以看出以上几种方法都有各自的缺陷,1和2一般不能满足需求,3和4的缺陷正好互补,两个事件结合起来使用可以兼容IE、firefox、chrome;
所以同时绑定[b]onpropertychange 和 [b][b]oninput 可以达到实时检测输入内容的目的[/b][/b][/b]
[b][b][b](jquery用[b][b]propertychange [b][b]和 [b][b]input[/b][/b][/b][/b][/b])。[/b][/b][/b][/b]
代码实例(jquery):
<!--superGG1990原创发表于博客园http://www.cnblogs.com/superGG1990,其他商业网站转载均为盗版,个人博客网站转载请注明出处 2017-05-12--> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>监听输入事件</title> <script type="text/javascript" src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script> <style> b {color:red; font-size:18px;} </style> </head> <body> <textarea style="width:800px; height:300px;"></textarea> <div>你已经输入了<b>0</b>个字</div> <script> $('textarea').on('input propertychange',function(){ var val = $(this).val() var textNum = val.length; if(textNum > 200){ textNum = 200; } $('b').html(textNum) //超过200个字提示 if(val.length>200){ var textVal = val.substring(0,200) $(this).val(textVal) alert('评论内容大于200字') } }) </script> </body> </html>
原文出处 superGG1990 www.cnblogs.com/superGG1990
相关文章推荐
- oninput、onchange与onpropertychange事件的区别, 与input输入框实时检测
- 实时监听输入框值变化的完美方案(兼容ie):oninput & onpropertychange
- 实时监听输入框值变化的完美方案:oninput & onpropertychange(真正完美,支持ie9以下,ie10,chrome)
- 监听输入框值变化的最佳方案 oninput 和 onpropertychange (实时监控文本框改变的最佳方案)
- jquery实现input输入框实时输入触发事件代码 ---jQuery 中bind(),live(),delegate(),on() 区别
- 实时监控文本框输入的信息,JS中的oninput & onpropertychange事件
- 输入框--仿placeholder,oninput检测用户输入事件
- easyui textbox 输入小写自动变大写,easyui textbox 绑定oninput事件 easyui textbox 绑定propertychange事件
- 同时支持火狐和IE的输入框内容改变事件
- 完美支持各种输入的事件绑定方法
- 兼容Firefox和IE的onpropertychange事件oninput
- 实时监听输入框值变化的完美方案:oninput & onpropertychange
- 实时监听输入框值变化的完美方案:oninput & onpropertychange
- TextArea输入变化事件,支持IOS中文手写
- onpropertychange、oninput监听input输入框值实时变化
- jquery实现input输入框实时输入触发事件
- jquery实现input输入框实时输入触发事件代码
- jsp name属性相同的一组输入框input,输入其中一个值,其余值跟随改变事件监听代码
- 兼容Firefox和IE的onpropertychange事件oninput
- Jquery文本框值改变事件(支持火狐、ie)