实时监听文本框输入

今天遇到一个这样的需求,需要根据用户的输入实时的检索出已输入文字匹配的东西出来,提示给用户看,html 标签中input的标签有onchange事件,onfocus事件,onblur事件,其中onchange事件,需要input标签失去焦点才会相应,onfocus则是获得焦点时才相应一次,onblur事件也是失去焦点后才相应,这与需求不太相关,通过不懈的百度以及google找到了一个解决方法,那就是onpropertychange事件,不过此事件存在兼容性问题,在ie下好用,而firefox,chrome等浏览器支持,不过有替代方法,那就是oninput事件。具体解决思路:一:在input标签上同时加上onpropertychange与oninput事件。二:判断浏览器类型,通过addEventListener方式为非ie浏览器添加oninput事件。

方法一源代码:

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. <div id="msg"></div>   
  2. <input id='txt' value="" onpropertychange="handle();" οninput="handle();"/>   
  3. <script>   
  4. //当状态改变的时候执行的函数   
  5. function handle()   
  6. {document.getElementById('msg').innerHTML='输入的文字长度为:'+document.getElementById('txt').value.length;   
  7. }   
  8. </script>   


方法二源代码:

[javascript]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. <div id="msg"></div>   
  2. <input id='txt' value="" />   
  3. <script type="text/javascript">  
  4.     function handle(){  
  5.         document.getElementById('msg').innerHTML="输入的文字长度为:"+document.getElementById('txt').value.length;  
  6.     }  
  7.     //firefox下检测状态改变只能用oninput,且需要用addEventListener来注册事件。   
  8.     if(/msie/i.test(navigator.userAgent))    //ie浏览器   
  9.         {document.getElementById('txt').onpropertychange=handle   
  10.     } else{//非ie浏览器,比如Firefox   
  11.         document.getElementById('txt').addEventListener("input",handle,false);   
  12.     }   
  13. </script>  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值