您的位置:首页 > 运维架构

oninput,onpropertychange,onchange的用法和区别

2014-11-28 08:58 459 查看
在某些web页面开发中,当一个HTML元素的属性改变的时候,我们会即时监听该属性的变化,以便作出即时动作去引导浏览者增强网站的用户体验感。

IE下,可用onpropertychange来即时捕获,onpropertychange 是IE浏览器的专属方法,只在IE下有效果,其它浏览器不起作用。

onchange在属性值改变时还必须使得当前元素失去焦点(onblur)才可以激活该事件。

<input type="text" name="textfield" onpropertychange="alert(this.value)" />  //在IE下通过文本框中的值触发事件,其它浏览器无效

几经查资料得知,在其他浏览器下可以使用oninput事件来达到同样的效果,这样我们可以这样写:

<input type="text" name="textfield" oninput="alert(this.value);" onpropertychange="alert(this.value)" />   //IE与其它浏览器均通过,有效

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

function addValue(){
      document.getElementById("mytext").value='改变值!';
      init();
}

function changeValue(){
      //事件处理
      alert("")
}
    
function init(){
     if("\v"=="v"){//IE浏览器
            document.getElementById("mytext").onpropertychange=changeValue;
      }else{ // 其他浏览器
            document.getElementById("mytext").addEventListener("input",changeValue(),false);
      }
}

<input type="button" id="mytext"  value="原始值!" onclick="addValue();"/>
以上实验代码(IE、火狐、谷歌可行)

总结:

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

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

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

oninput事件是IE之外的大多数浏览器支持的事件,在value改变时触发,实时的,即每增加或删除一个字符就会触发,然而通过js改变value时,却不会触发;onpropertychange事件是任何属性改变都会触发的,而oninput却只在value改变时触发,oninput要通过addEventListener()来注册,onpropertychange注册方式跟一般事件一样。(此处都是指在js中动态绑定事件,以实现内容与行为分离)

3、oninput与onpropertychange失效的情况:

(1)oninput事件:a). 当脚本中改变value时,不会触发;b). 从浏览器的自动下拉提示中选取时,不会触发。

(2)onpropertychange事件:当input设置为disable=true后,onpropertychange不会触发。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息