美文网首页让前端飞程序员
change、propertychange 和 input 事件

change、propertychange 和 input 事件

作者: 科研者 | 来源:发表于2017-10-11 12:55 被阅读0次

    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 失效的情况:

    oninput 事件:

    • 当脚本中改变 value 时,不会触发;
    • 从浏览器的自动下拉提示中选取时,不会触发;

    onpropertychange 事件:

    • 当 input 设置为 disable=true 后,onpropertychange 不会触发;

    相关文章

      网友评论

        本文标题:change、propertychange 和 input 事件

        本文链接:https://www.haomeiwen.com/subject/ssqwyxtx.html