美文网首页
javascript事件传递机制

javascript事件传递机制

作者: sdupidBoby | 来源:发表于2017-11-29 11:25 被阅读56次
事件传递机制

(*useful)标记:目前觉得有用的函数
//FIXME 标记:待补充

系统接收到触摸会把触摸操作放入runloop的队列中 (*useful)
  1. 接收触摸顺序(事件的产生,传递):
    UIApplication -> window - > viewA(divA) -> viewB(divB)
  2. 事件冒泡顺序(事件的响应链):
    viewB(divB) - > viewA(divA) -> window -> UIApplication

JS:
addEventListener(eventName,handlers,boolean:useCapture)
useCapture=false:将事件处理函数加入到冒泡阶段,在冒泡阶段会被调用;
useCapture=true:将事件处理函数加入到捕获阶段,在捕获阶段会被调用;

iOS:
事件传到UIApplication还不能被处理,就会触发 消息转发 (*useful)
-(void)forwardInvocation:(NSInvocation *)invocation
hitTest:withEvent:方法 :可以用来拦截返回相应的View (返回nil,事件继续传递
pointInside:withEvent:方法 :判断事件是否在某个view中


DOM0级事件处理程序

.onclick
例子:

1 var btn5 = document.getElementById('btn5');
2 btn5.onclick=function(){
3    console.log(this.id);//btn5   
4 };

DOM2级事件处理程序

监听:

  1. addEventListener(eventName,handlers,boolean);
  2. removeEventListener()

两个方法都一样接收三个参数:

  • 第一个是要处理的事件名,
  • 第二个是事件处理程序,
  • 第三个值为false时表示在事件冒泡阶段调用事件处理程序,一般建议在冒泡阶段使用,特殊情况才在捕获阶段;
1 var btn2 = document.getElementById('btn2');
2 var handlers = function () {
3    console.log(this.id);
4 };
5 
6 btn2.addEventListener('click',handlers,false);
7 
8 btn2.removeEventListener('click',handlers.false);

IE事件处理程序

//IE事件处理程序(IE和Opera支持)
//IE用了attachEvent(),detachEvent(),接收两个参数,事件名称和事件处理程序,通过attachEvent()添加的事件处理程序都会被添加到冒泡阶段,所以平时为了兼容更多的浏览器最好将事件添加到事件冒泡阶段,IE8及以前只支持事件冒泡;

1 var btn3 = document.getElementById('btn3');
2 var handlers2=function(){
3    console.log(this===window);//true,注意attachEvent()添加的事件处理程序运行在全局作用域中;
4 };
5 btn3.attachEvent('onclick',handlers2);

跨浏览器事件处理程序

   // 添加句柄  
         addHandler:function(element,type,handler){  
               if(element.addEventListener){   // DOM2级  
                 element.addEventListener(type,handler,false);  
               }else if(element.attachEvent){   // IE浏览器  
                 element.attachEvent('on'+type,handler);  
               }else{   // DOM0级  
                 element['on'+type]=handler;  
               }  
         },

初步理解JS的事件机制

相关文章

  • javascript事件传递机制

    (*useful)标记:目前觉得有用的函数//FIXME 标记:待补充 系统接收到触摸会把触摸操作放入runlo...

  • JavaScript事件传递机制Event Propagatio

    event propagation事件冒泡 element.addEventListener('click', l...

  • 深入浅出iOS事件机制

    深入浅出iOS事件机制事件传递:响应链事件传递响应链

  • javascript 中的事件机制

    js之事件机制 1、事件初探 1.1 js事件的概述 JavaScript事件:JavaScript是基于事件驱动...

  • JavaScript的事件机制

    在JavaScript的学习中,我们经常会遇到JavaScript的事件机制,例如,事件绑定、事件监听、事件委托(...

  • 安卓事件传递机制

    事件传递机制 View dispatchTouchEvent():分发事件 onTouchEvent():处理事件...

  • 01进阶之路-UI视图

    1. 事件传递机制和响应者链条 学习链接 事件传递机制iOS中的事件可以分为3大类型 1 触摸事件 2 加速计...

  • 事件传递机制

    主要内容 理论部分 常见应用 理论部分 iOS中事件(UIEvent)主要是以下几种,本文主要是分析触控事件(UI...

  • 事件传递机制

    ActivitydispatchTouchEvent 返回true false 将会在自己的dispatchTou...

  • 事件传递机制

    一般来说:Activity------>Window--------->DevorView(setContentV...

网友评论

      本文标题:javascript事件传递机制

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