美文网首页
那些小区别

那些小区别

作者: 吹蒲公英的猫 | 来源:发表于2016-11-24 16:37 被阅读0次

    target与currentTarget区别
    只有当事件流处在目标阶段的时候,两个的指向才是一样的, 而当处于捕获和冒泡阶段的时候,target指向被单击的对象而currentTarget指向当前事件活动的对象(一般为父级)。target在事件流的目标阶段;currentTarget在事件流的捕获,目标及冒泡阶段。
    oninput、onchange与onpropertychange区别
    1、onchange/onkeyup/onkeypress/onkeydown,onchange只是在键盘鼠标手动操作,只有元素发生改变的时候才能立即触发。脚本触发无效。;onkeydown/onkeyup/onkeypress在处理复制、粘贴、拖拽、长按键等细节上也是存在问题的。
    2、onpropertychange属性可在某些情况下解决上面存在的问题。不用考虑是否失去焦点,不管是js还是键盘鼠标手动操作。只要html元素属性发生改变即可捕获,但是,onpropretychange为IE专属的!其他浏览器要监听就要用html5的oninput,不过IE9以下的浏览器不支持oninput。
    3、恩,然后我们需要综合oninput和onpropertychange二者来实现文本区域监听的功能。
    4、对IE使用onpropertychange,其他浏览器用oninput:

    var ie = !!window.ActiveXObject;  
    if(ie){  
        object.onpropertychange = fn;  
    }else{  
        object.addEventListener("input",fn,false);  
    } 
    
    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不会触发。 
    

    相关文章

      网友评论

          本文标题:那些小区别

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