jQuery的DOM事件

2018-12-25  本文已影响0人  陈裔松的技术博客

jQuery的事件模型

添加事件处理

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的所有命名空间
上一篇下一篇

猜你喜欢

热点阅读