jQuery事件绑定

一、静态绑定事件

如:在执行完bind()方法给所有button添加点击事件的操作后,又往页面动态添加了button元素,那么后来添加的button并没有前面添加的点击事件。

1.bind()方法 —— 静态绑定事件

jQuery 3.0中已弃用此方法,使用 on()方法代替。

$(selector).bind(events,[data],fn)

events: 含有一个或多个事件类型的字符串,由“空格”分隔多个事件。比如"click"或"submit",还可以是自定义事件名。

data:作为event.data属性值传递给事件对象的额外数据对象(可省略)。

fn:绑定到每个匹配元素的事件上面的处理函数。

代码示例:

绑定多个事件但是操作一样,事件中间使用“空格”分隔,参数通过事件获得。

$("form").bind("submit click", "参数", function(event){
alert(event.data); // 获得参数 // 其他操作 });

绑定多个事件且操作不同,使用json。

$("form").bind({
    click:function(){},
    mouseover:function(){}
});

2.unbind()方法 —— 解除事件绑定

$(selector).unbind():解除所有事件

$(selector).unbind(type):解除特定事件

$(selector).unbind(type,handler):解除特定事件特定方法

type:时间类型字符串

handler:想要接触的方法

代码示例:

// 绑定事件
var fn1 = function(){} var fn2 = function(){} var fn3 = function(){} $("form").bind({ click:fn1, click:fn2, click:fn3 });
// 解除绑定
$("form").unbind("click",fn2);

结果:方法fn2被解除绑定,其他两个方法还在。

二、动态绑定事件

1.on()方法 —— 动态绑定事件

如:在执行完on()方法给所有button添加点击事件的操作后,又往页面动态添加了button元素,那么后来添加的button也有前面添加的点击事件,注意第一个selector不能是动态添加的。

$(selector).on(events,selector,data,fn);

events: 含有一个或多个事件类型的字符串,由“空格”分隔多个事件。比如"click"或"submit",还可以是自定义事件名。

selector:一个选择器字符串,用于过滤触发事件的所选元素的后代。

data:作为event.data属性值传递给事件对象的额外数据对象(可省略)。

fn:绑定到每个匹配元素的事件上面的处理函数。

$(document).on("click",":button",function(){});

2.off()方法 —— 动态解绑事件

$(selector).off():解绑所有事件

$(selector).off(events):解绑特定事件(选择器由绑定时是否有决定)

$(selector).off(events,selector):解绑特定事件(选择器由绑定时是否有决定)

$(selector).off(events,selector,handler):解绑特定事件的特定方法