jQuery的DOM事件

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的所有命名空间
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容