美文网首页
jQuery的DOM事件

jQuery的DOM事件

作者: 陈裔松的技术博客 | 来源:发表于2018-12-25 13:41 被阅读0次

    jQuery的事件模型

    • 提供了统一的事件处理方法,不需要再考虑兼容性问题
    • 允许添加多个事件处理函数,jQuery内部使用DOM2级事件模型的处理方式
    • 使用标准事件名称(不带on)
    • 事件实例作为事件处理函数的第一个参数
    • 标准化事件实例中最常用的属性
    • 提供了统一的事件取消和阻止默认行为的方法

    添加事件处理

    1,on方法
    // on(eventType[,selector][,data],handler)
    // 参数1(eventType): 事件类型
    // 参数2(selector):   一般在事件委托的时候会需要
    // 参数3(data): 传递一些数据给事件处理函数。在事件处理函数中,可以通过event.data获取
    // 参数4(handler): 事件处理函数
    
    // 事件委托:在父元素上添加事件,利用事件冒泡机制,当在子元素上操作时,会触发父元素的事件,提高性能和灵活性。
    
    // 简单的事件绑定
    $('li').on('click',function(event){
        console.log('%o li clicked',$(this));
    });
    
    // 复杂的事件绑定,用到事件委托,数据传递
    $('div').on('click','#p1-1',{foo:'bar'},function(event){
        console.log('p clicked %o',event.data);
    }).on('mouseover','#p1-1',{foo:'bar'},function(event){
        console.log('p clicked %o',event.data);
    })
    
    //!!放在父元素上也是可以的,用到的是冒泡机制!!
    $('ul').on('click',function(event){
        console.log('%o clicked',$(event.target));
    });
    
    2,统一方法和属性
    //stopPropagation():阻止冒泡
    
    //preventDefault():阻止默认行为
    
    //阻止冒泡和默认行为:return false
    
    $('div').on('click',function(event){
        event.stopPropagation();
        console.log('%o clicked',$(this));
    })
    
    //所有支持的事件
    //blur,change,click,dblclick,error,focus,focusin,
    //focusout,keydown,keypress,keyup,load,unload
    
    //mousedown,mouseenter,mouseleave,mousemove,mouseout,mouseover
    //mouseup,ready,resize,scroll,select,submit
    
    3,one方法
    //one(eventType[,selector][,data],handler) 一次性的事件处理
    $('p').one('click',function(event){
        console.log('%o clicked',$(this));
    });
    

    移除事件处理

    //off(eventType[,selector][,handler])
    
    $('p').on('click',function(){
        console.log('clicked');
    }).on('click',clicked2)
    
    $('p').off();                   // 移除所有事件
    $('p').off('click');            // 移除所有click事件
    $('p').off('click mouse');      // 移除所有click事件和mouse事件
    $('p').off('click',clicked2);   // 移除click事件中的clicked2处理
    

    事件实例对象

    属性
    // 以下带*的属性存在兼容性问题,且jQuery对其做了兼容性处理
    
    altKey              originalTarget      ctrlKey             screenX
    bubbles             originalEvent       currentTarget       screenY
    button              pageX *             data                shiftKey
    cancelable          pageY *             detail              target *
    charCode            prevValue           delegateTarget      timeStamp
    clientX             relateTarget *      eventPhase          type
    clientY             result              metaKey *           view
    namespace           which *             offsetX             offsetY
    
    事件
    //preventDefault()          :阻止浏览器的默认事件,比如点击超链接进行跳转
    //stopPropagation()         :阻止冒泡
    //stopImmediatePropagation():阻止本身以外的所有事件
    
    $('div').on('click',function(event){
        // event.stopPropagation();         //阻止冒泡
        event.stopImmediatePropagation();   //下面的事件也不会执行
        console.log('clicked %o',$(this));
    }).on('click',function(event){
        console.log('clicked2 %o',$(this));
    })
    
    //isDefaultPrevented()              :是否调用了preventDefault()
    //isPropagationStopped()            :是否调用了stopPropagation()
    //isImmediatePropagationStopped()   :是否调用了stopImmediatePropagation()
    

    触发事件

    //trigger(eventType[,data])
    //triggerHandler(eventType[,data])  
    
    //triggerHandler相比trigger:
    //不会触发浏览器默认事件
    //不会产生事件冒泡
    //只触发jQuery对象集合中第一个元素的事件处理函数
    //返回的是事件处理函数的返回值,而不是jQuery对象
    
    // 一般的事件触发
    $('li').on('click',function(event){
        console.log('已读 %o',$(this));
        return '123';
    })
    $('#all').on('click',function(){    
        console.log($('li').trigger('click'));          // 触发所有li元素的click事件
        console.log($('li').triggerHandler('click'));   // 触发第一个里元素的click事件
    })
    
    // 带数据的事件触发
    $('li').on('click',function(event,arg1,arg2){
        console.log('已读 %o',$(this));
        return '123';
    })
    $('#all').on('click',function(){
        $('li').trigger('click',[1,2]);
    })
    

    快捷方法

    blur,change,click,dblclick,focus,focusin,focusout,keydown,keypress,keyup
    mousedown,mouseenter,mouseleave,mousemove,mouseout,mouseover,mouseup
    ready,resize,scroll,select,submit

    //绑定事件:eventName([data,]handler)
    //触发事件:eventName()
    
    // 绑定事件
    $('li').click(function(event){
        console.log('已读 %o',$(this));
        return '123';
    })
    //触发事件
    $('#all').on('click',function(){
        $('li').click();    //触发事件
    })
    

    hover

    //hover方法
    //jQuery自带的方法,浏览器并不具备
    //目的是为了弥补onmouseover()和onmouseout()的不足
    
    function report(event){
        event.stopPropagation();
        console.log(event.type + ' on ' + event.target.id);
    }
    
    // 不足:在鼠标移入inner1的时候,会触发outer1的mouseout事件,这不是我们想要的效果
    $('#outer1').on('mouseover mouseout',report);
    $('#inner1').on('mouseover mouseout',report);
    
    // 在鼠标移入inner1的时候,只会触发inner1的mouseover事件,这是我们想要的效果
    $('#outer2').hover(report);
    $('#inner2').hover(report);
    

    自定义事件

    // on(customEvent)
    // trigger(customEvent)
    
    $('li').on('markAsRead',function(event){
        console.log('已读 %o',$(this));
    }).on('click',function(){
        $(this).trigger('markAsRead');
    })
    
    $('#all').on('click',function(){
        $('li').trigger('markAsRead');
    })
    

    事件命名空间

    // eventName.namespace
    
    $('li:odd').on('click.even',function(e){
        console.log('%o 偶数',$(this))
    })
    $('li:even').on('click.odd',function(e){
        console.log('%o 奇数',$(this))
    })
    $('li').eq(0).on('click.even.0',function(e){
        console.log('%o 0',$(this))
    })
    
    $('#even').click(function(){
        $('li').trigger('click.even');      //同时会触发even的子命名空间内容(也就是even.0)
    })
    
    $('#odd').click(function(){
        $('li').trigger('click.odd');
    })
    
    //删除事件
    $('li').off('.even');   //删除even的所有命名空间
    

    相关文章

      网友评论

          本文标题:jQuery的DOM事件

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