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不会触发。
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不会触发。
相关文章推荐
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别(纠正网络版)
- 总结oninput、onchange与onpropertychange事件的用法和区别,onchange
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- 【转】总结oninput、onchange与onpropertychange事件的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange和onchange的区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别
- oninput,onpropertychange,onchange的用法和区别