input标签内容改变的触发事件

来源:互联网 发布:猎鹿帽为什么前后 知乎 编辑:程序博客网 时间:2024/05/15 12:40

1. onchange事件与onpropertychange事件的区别:

  onchange事件在内容改变(两次内容有可能相等)且失去焦点时触发;onpropertychange事件是实时触发,每增加或删除一个字符就会触发,通过js改变也会触发该事件,但是该事件是IE专有。

2. oninput事件与onpropertychange事件的区别:

  oninput事件是IE之外的大多数浏览器支持的事件,在value改变时实时触发,但是通过js改变value时不会触发;onpropertychange事件是任何属性改变都会触发,而oninput却只在value改变时触发,oninput要通过addEventListener()来注册,onpropertychange注册方法与一般事件相同。

3. oninput与onpropertychange失效的情况:

oninput事件:

  (1)当脚本中改变value时,不会触发;

  (2)从浏览器的自动下拉提示中选取时,不会触发;

onpropertychange事件:

  当input设置为disable=true后,不会触发。


 判断IE浏览器
    如何将IE区分出来呢?

if("\v"=="v") {
  alert("IE");
}else{
  alert("NO");
}


 代码实现

if("\v"=="v") {
element.onpropertychange = webChange;
}else{
element.addEventListener("input",webChange,false);   

//注意此处是Dom对象,jquery对象会导致错误

  //Dom对象,jquery对象的介绍
}
function webChange(){
if(element.value){

document.getElementById("test").innerHTML = element.value

};
}


参考网址:

1、http://www.cnblogs.com/sydeveloper/p/3794079.html

2、http://blog.csdn.net/zhbitxhd/article/details/12943091

0 0
原创粉丝点击