输入框监听输入事件

参考http://www.imf7.com/archives/28

要达到的效果

很多情况下我们都会即时监听输入框值的变化,以便作出即时动作去引导浏览者增强网站的用户体验感。比如即时显示输入框已经被输入的字节数,或者即时读取输入的值来进行搜索引导,也就是google的关联搜索效果等。只要我们能捕获即时事件就能做到很多事情。

需要了解的知识

首先,我们需要了解onchange和onpropertychange的不同

IE下,当一个HTML元素的属性改变的时候,都能通过 onpropertychange来即时捕获。
onchange在属性值改变时还必须使得当前元素失去焦点(onblur)才可以激活该事件。

了解这一点后我们发现onpropertychange的效果就是我们想要的,可是很遗憾,它只在IE下有效果。我们能不能找到另外一个时间来代替onpropertychange呢?

经过翻阅资料得知,在其他浏览器下可以使用oninput事件来达到同样的效果,真是太好了,我们只需要把IE浏览器区分出来就可以。

oninput的使用

下面我们先了解一下oninput如何使用。
如果您是将注册时间直接写在页面里面,那么如下写法就可以实现:

<input type="text" name="textfield" oninput="alert(this.value);" onpropertychange="alert(this.value)" />

但是,将oninput写在JS代码中分离出来时与普通事件注册的方法有些不同,必须使用addEventListener来注册。

attachEvent和addEventListener 的不同

说到这里我们再来了解一下 attachEvent和addEventListener 的使用方法

attachEvent方法,为某一事件附加其它的处理事件。(不支持Mozilla系列)
addEventListener方法 用于 Mozilla系列

判断浏览器类型

1只区分ie浏览器还是非ie

function immediately(){
  var element = document.getElementById("mytext");
  if("\v"=="v") {
element.onpropertychange = webChange;
  }else{
element.addEventListener("input",webChange,false);
  }

2区分各种浏览器

function getOs(){//判断浏览器类型
var OsObject = "";
if(navigator.userAgent.indexOf("MSIE")>0) {
return "MSIE";
}
if(isFirefox=navigator.userAgent.indexOf("Firefox")>0){
return "Firefox";
}
if(isSafari=navigator.userAgent.indexOf("Safari")>0) {
return "Safari";
}
if(isCamino=navigator.userAgent.indexOf("Camino")>0){
return "Camino";
}
if(isMozilla=navigator.userAgent.indexOf("Gecko/")>0){
return "Gecko";
}

}

总结:

onchange:文本框输入值且失去焦点后触发,通过赋值或粘贴方式改变值时不触发

onpropertychange:仅ie支持,文本框属性发生任何改变,包括键盘输入任何值,或者通过赋值都能触发

oninput:非ie浏览器,文本框输入值后触发(无需失去焦点),通过赋值改变值时不触发

onkeyup:当键盘按下并放开时触发

注意:采用onpropertychange时,当输入一个汉字或者字符,数字等都不能触发事件,当再次输入第二个字符汉字或数字后才能触发,后改为了onkeyup就可以了,请教高手为什么输入一个的时候就不行呢

posted @ 2012-02-08 14:24  Irene198505  阅读(797)  评论(0编辑  收藏  举报