jQuery 事件( jQuery 事件方法/绑定事件/解绑事件/触发事件/事件对象)

jQuery 事件

jQuery 是为事件处理特别设计的。

jQuery的事件机制,指的是:jQuery对JavaScript操作DOM事件的封装,包括了:事件绑定、事件解绑、事件触发。

jQuery事件的发展历程 简单事件绑定 >> bind事件绑定 >> delegate事件绑定 >> on

什么是事件?

页面对不同访问者的响应叫做事件。
事件处理程序指的是当 HTML 中发生某些事件时所调用的方法。

实例:

1).在元素上移动鼠标。
2).选取单选按钮
3).点击元素
在事件中经常使用术语"触发"(或"激发")例如: “当您按下按键时触发 keypress 事件”。

常见 DOM 事件:

事件函数 说明
click(handler) 单击事件
blur(handler) 失去焦点事件
mouseenter(handler) 鼠标进入事件
mouseleave(handler) 鼠标离开事件
dbclick(handler) 双击事件
change(handler) 改变事件,如:文本框值改变,下来列表值改变等
focus(handler) 获得焦点事件
keydown(handler) 键盘按下事件

jQuery 事件方法语法

在 jQuery 中,大多数 DOM 事件都有一个等效的 jQuery 方法。
页面中指定一个点击事件:

$("p").click();

下一步是定义什么时间触发事件。您可以通过一个事件函数实现:

$("p").click(function(){
    // 动作触发后执行的代码!!
});

常用的 jQuery 事件方法

1.$(document).ready()
$(document).ready() 方法允许我们在文档完全加载完后执行函数。该事件方法在 jQuery 语法 章节中已经提到过。

2.click()
click() 方法是当按钮点击事件被触发时会调用一个函数。

该函数在用户点击 HTML 元素时执行。

在下面的实例中,当点击事件在某个

元素上触发时,隐藏当前的

元素:

//实例
$("p").click(function(){
  $(this).hide();
});

3.dblclick()
当双击元素时,会发生 dblclick 事件。

dblclick() 方法触发 dblclick 事件,或规定当发生 dblclick 事件时运行的函数:

//实例
$("p").dblclick(function(){
  $(this).hide();
});

4.mouseenter()
当鼠标指针穿过元素时,会发生 mouseenter 事件。

mouseenter() 方法触发 mouseenter 事件,或规定当发生 mouseenter 事件时运行的函数:

//实例
$("#p1").mouseenter(function(){
    alert('您的鼠标移到了 id="p1" 的元素上!');
});
	

5.mouseleave()
当鼠标指针离开元素时,会发生 mouseleave 事件。

mouseleave() 方法触发 mouseleave 事件,或规定当发生 mouseleave 事件时运行的函数:

//实例
$("#p1").mouseleave(function(){
    alert("再见,您的鼠标离开了该段落。");
});
	

6.mousedown()
当鼠标指针移动到元素上方,并按下鼠标按键时,会发生 mousedown 事件。

mousedown() 方法触发 mousedown 事件,或规定当发生 mousedown 事件时运行的函数:

//实例
$("#p1").mousedown(function(){
    alert("鼠标在该段落上按下!");
});

7.mouseup()
当在元素上松开鼠标按钮时,会发生 mouseup 事件。

mouseup() 方法触发 mouseup 事件,或规定当发生 mouseup 事件时运行的函数:

//实例
$("#p1").mouseup(function(){
    alert("鼠标在段落上松开。");
});

8.hover()
hover()方法用于模拟光标悬停事件。

当鼠标移动到元素上时,会触发指定的第一个函数(mouseenter);当鼠标移出这个元素时,会触发指定的第二个函数(mouseleave)。

//实例
$("#p1").hover(
    function(){
        alert("你进入了 p1!");
    },
    function(){
        alert("拜拜! 现在你离开了 p1!");
    }
);

9.focus()
当元素获得焦点时,发生 focus 事件。

当通过鼠标点击选中元素或通过 tab 键定位到元素时,该元素就会获得焦点。

focus() 方法触发 focus 事件,或规定当发生 focus 事件时运行的函数:

//实例
$("input").focus(function(){
  $(this).css("background-color","#cccccc");
});

10.blur()
当元素失去焦点时,发生 blur 事件。

blur() 方法触发 blur 事件,或规定当发生 blur 事件时运行的函数:

//实例
$("input").blur(function(){
  $(this).css("background-color","#ffffff");
});

事件绑定

1.bind方式
作用:给匹配到的元素直接绑定事件(不推荐,1.7以后的jQuery版本被on取代)

// 绑定单击事件处理程序
第一个参数:事件类型
第二个参数:事件处理程序
$("p").bind("click mouseenter", function(e){
    //事件响应方法
});

优点:可以同时绑定多个事件,比如:bind(“mouseenter mouseleave”, function(){})

缺点:仍然无法给动态创建的元素绑定事件

2.delegate方式

作用:给匹配到的元素绑定事件,对支持动态创建的元素有效(特点:性能高,支持动态创建的元素)

// 第一个参数:selector,要绑定事件的元素
// 第二个参数:事件类型
// 第三个参数:事件处理函数
$(".parentBox").delegate("p", "click", function(){
    //为 .parentBox下面的所有的p标签绑定事件
});

与前两种方式最大的优势:减少事件绑定次数提高效率,支持动态创建出来的元素绑定事件

注意:mouseover与mouseenter的区别:
mouseover冒泡,mouseenter不冒泡

3.on方式
(最现代的方式,兼容zepto(移动端类似jQuery的一个库),强烈建议使用的方式)

jQuery1.7版本后,jQuery用on统一了所有的事件处理的方法
作用:给匹配的元素绑定事件,包括了上面所有绑定事件方式的优点

//参数1:events,绑定事件的名称可以是由空格分隔的多个事件 //参数2:selector, 执行事件的后代元素
//参数3:data,传递给处理函数的数据,事件触发的时候通过event.data来使用 //参数4:handler,事件处理函数
$(selector).on(events[,selector][,data],handler);

//表示给$(selector)绑定事件,但必须是它的内部元素span才能执行这个事件
$(selector).on( "click",“span”, function() {});
 
// 绑定多个事件
// 表示给$(selector)匹配的元素绑定单击和鼠标进入事件
$(selector).on(“click mouseenter”, function(){});

解绑事件

1.unbind() 方式

作用:解绑 bind方式绑定的事件

$(selector).unbind(); //解绑所有的事件
$(selector).unbind(“click”); //解绑指定的事件

2.undelegate() 方式

作用:解绑delegate方式绑定的事件

$( selector ).undelegate(); //解绑所有的delegate事件
$( selector).undelegate( “click” ); //解绑所有的click事件

3.off解绑on方式绑定的事件

// 解绑匹配元素的所有事件
$(selector).off();
// 解绑匹配元素的所有click事件
$(selector).off(“click”);
// 解绑所有代理的click事件,元素本身的事件不会被解绑
$(selector).off( “click”,**);

事件触发

简单事件触发

$(selector).click(); //触发 click事件

trigger方法触发事件

$(selector).trigger(“click”);

triggerHandler触发 事件响应方法,不触发浏览器行为

比如:文本框获得焦点的默认行为

$(selector).triggerHandler(“focus”);

jQuery事件对象介绍

事件 说明
event.pageX 鼠标相对于页面左边的位置
event.target 触发该事件的元素(事件目标)
event.currentTarget 该事件所针对的元素对象
event.keyCode 键盘按键代码
event.stopPropagation(); 阻止事件冒泡
event.preventDefault(); 阻止默认行为
event.type 事件类型:click,dbclick…
event.which 鼠标的按键类型:左1 中2 右3
event.data 传递给事件处理程序的额外数据

return false; // 也具有阻止冒泡和阻止默认行为的功能
this:事件处理函数针对哪个元素对象,this就指向哪个元素对象

发布了24 篇原创文章 · 获赞 73 · 访问量 5933

猜你喜欢

转载自blog.csdn.net/zyfacd/article/details/104973170