jQuery 基础事件

JavaScript 有一个非常重要的功能,就是事件驱动。当页面完全加载后,用户通过鼠标 或键盘触发页面中绑定事件的元素即可触发。jQuery 为开发者更有效率的编写事件行为,封 装了大量有益的事件方法供我们使用。

一.绑定事件

在 JavaScript 课程的学习中,我们掌握了很多使用的事件,常用的事件有:click、dblclick、 mousedown、mouseup、mousemove、mouseover、mouseout、change、select、submit、keydown、 keypress、keyup、blur、focus、load、resize、scroll、error。那么,还有更多的事件可以参考 手册中的事件部分。

jQuery 通过.bind()方法来为元素绑定这些事件。可以传递三个参数:bind(type,[data],fn), type 表示一个或多个类型的事件名字符串;[data]是可选的,作为 event.data 属性值传递一个 额外的数据,这个数据是一个字符串、一个数字、一个数组或一个对象;fn 表示绑定到指 定元素的处理函数。

//使用点击事件

$(‘input‘).bind(‘click‘,function(){ //点击按钮后执行匿名函数

alert(‘点击!‘);

});

//普通处理函数

$(‘input‘).bind(‘click‘,fn); //执行普通函数式无须圆括号

function fn(){

alert(‘点击!‘);

}

//可以同时绑定多个事件

$(‘input‘).bind(‘mouseout mouseover‘, function(){ //移入和移出分别执行一次

$(‘div‘).html(function(index,value){

returnvalue+‘1‘;

});

});

//通过对象键值对绑定多个参数

$(‘input‘).bind({   //传递一个对象

‘mouseout‘:function(){   //事件名的引号可以省略

alert(‘移出‘);

},

‘mouseover‘:function(){

alert(‘移入‘);

}

});

//使用 unbind 删除绑定的事件

$(‘input‘).unbind(); //删除所有当前元素的事件

//使用 unbind 参数删除指定类型事件

$(‘input‘).unbind(‘click‘); //删除当前元素的 click 事件

//使用 unbind 参数删除指定处理函数的事件

function fn1(){

alert(‘点击 1‘);

}

function fn2(){

alert(‘点击 2‘);

}

$(‘input‘).bind(‘click‘,fn1);

$(‘input‘).bind(‘click‘,fn2);

$(‘input‘).unbind(‘click‘,fn1); //只删除 fn1 处理函数的事件

二.简写事件

为了使开发者更加方便的绑定事件,jQuery 封装了常用的事件以便节约更多的代码。我 们称它为简写事件

注意:这里封装的大部分方法都比较好理解,我们没必要一一演示确认,重点看几个需 要注意区分的简写方法。

.mouseover()和.mouseout()表示鼠标移入和移出的时候触发。那么 jQuery 还封装了另外 一组:.mouseenter()和.mouseleave()表示鼠标穿过和穿出的时候触发。那么这两组本质上有 什么区别呢?手册上的说明是:.mouseenter()和.mouseleave()这组穿过子元素不会触发, 而.mouseover()和.mouseout()则会触发。

//HTML 页面设置

<div style="width:200px;height:200px;background:green;">

<p style="width:100px;height:100px;background:red;"></p>

</div>

<strong></strong>

//mouseover 移入

$(‘div‘).mouseover(function(){   //移入 div 会触发,移入 p 再触发

$(‘strong‘).html(function(index,value){

returnvalue+‘1‘;

});

});

//mouseenter 穿过

$(‘div‘).mouseenter(function(){ //穿过 div 或者 p

$(‘strong‘).html(function(index,value){ //在这个区域只触发一次

return value+‘1‘;

});

});

//mouseout 移出

$(‘div‘).mouseout(function(){ //移出 p 会触发,移出 div 再触发

$(‘strong‘).html(function(index,value){

return value+‘1‘;

});

});

//mouseleave 穿出

$(‘div‘).mouseleave(function(){ //移出整个 div 区域触发一次

$(‘strong‘).html(function(index,value){

return  value+‘1‘;

});

});

//.keydown()、.keyup()返回的是键码,而.keypress()返回的是字符编码。

$(‘input‘).keydown(function(e){

alert(e.keyCode); //按下 a 返回 65

});

$(‘input‘).keypress(function(e){

alert(e.charCode); //按下 a 返回 97

});

注意:e.keyCode 和 e.charCode 在两种事件互换也会产生不同的效果,除了字符还有一 些非字符键的区别。更多详情可以了解 JavaScript 事件处理那章。

.focus()和.blur()分别表示光标激活和丢失,事件触发时机是当前元素。而.focusin() 和.focusout()也表示光标激活和丢失,但事件触发时机可以是子元素。

//HTML 部分

<div style="width:200px;height:200px;background:red;">

<input type="text"value=""/>

</div>

<strong></strong>

//focus 光标激活

$(‘input‘).focus(function(){ //当前元素触发

$(‘strong‘).html(‘123‘);

});

//focusin 光标激活

$(‘div‘).focusin(function(){ //绑定的是 div 元素,子类 input 触发

$(‘strong‘).html(‘123‘);

});

注意:.blur()和.focusout()表示光标丢失,和激活类似,一个必须当前元素触发,一个可 以是子元素触发。

三.复合事件 

jQuery 提供了许多最常用的事件效果,组合一些功能实现了一些复合事件,比如切换功 能、智能加载等

//背景移入移出切换效果

$(‘div‘).hover(function(){

$(this).css(‘background‘,‘black‘); //mouseenter 效果

},function(){

$(this).css(‘background‘,‘red‘); //mouseleave 效果,可省略

});

注意:.hover()方法是结合了.mouseenter()方法和.mouseleva()方法,并非.mouseover() 和.mouseout()方法。

.toggle()这个方法比较特殊,这个方法有两层含义,第一层含义就是已经被 1.8 版废用、 1.9 版删除掉的用法,也就是点击切换复合事件的用法。第二层函数将会在动画那里讲解到。

既然废弃掉了,就不应该使用。被删除的原因是:以减少混乱和提高潜在的模块化程度。 但你又非常想用这个方法,并且不想自己编写类似的功能,可以下载 jquery-migrate.js 文件,来向下兼容已被删除掉的方法。

//背景点击切换效果(1.9 版删除掉了)

<scripttype="text/javascript"src="jquery-migrate-1.2.1.js"></script>

$(‘div‘).toggle(function(){ //第一次点击切换

$(this).css(‘background‘,‘black‘);

},function(){ //第二次点击切换

$(this).css(‘background‘,‘blue‘);

},function(){ //第三次点击切换

$(this).css(‘background‘,‘red‘);

});

注意:由于官方已经删除掉这个方法,所以也是不推荐使用的,如果在不基于向下兼容 的插件 JS。我们可以自己实现这个功能。

var flag=1; //计数器

$(‘div‘).click(function(){

if(flag==1){ //第一次点击

$(this).css(‘background‘,‘black‘);

flag=2;

}elseif(flag==2){ //第二次点击

$(this).css(‘background‘,‘blue‘);

flag=3

}elseif(flag==3){ //第三次点击

$(this).css(‘background‘,‘red‘);

flag=1

}

});

时间: 2024-12-29 11:36:36

jQuery 基础事件的相关文章

jQuery基础——事件篇

jQuery基础--事件篇 鼠标事件 click与dbclick事件 click方法监听用户单击操作,dbclick监听用户双击操作,这两个方法类似. dbclick与click事件不同的是: click事件触发需要以下几点: click事件其实是由mousedown与mouseup 2个动作构成,所以点击的动作只有在松手后才触发 dblclick事件触发需要以下几点: dblclick又是由2个click叠加而来的,所以dblclick事件只有在满足以下条件的情况下才能被触发 鼠标指针在元素里

jquery基础事件

一.常用的事件有:click.dblclick. mousedown.mouseup.mousemove.mouseover.mouseout.change.select.submit.keydown. keypress.keyup.blur.focus.load.resize.scroll.error..... 二.Query 通过.bind()方法来为元素绑定这些事件.可以传递三个参数:bind(type,[data],fn): type 表示一个或多个类型的事件名字符串. [data]是可

jQuery基础-事件

只能添加一个处理函数,后面的会覆盖前面 会有兼容性差异 冒泡 会依次检查父元素 截获冒泡 或者 最大的缺陷 并且在IE和NetSpace里面分别为冒泡和捕获两种 多个处理函数 依次执行 捕获--->自己--->冒泡 true 只捕获,不冒泡 false 只冒泡 从父元素的处理事件开始执行 又想捕获又想冒泡怎么办? true和false都写一次 jQuery就处理了很多兼容性的差异 绑定事件 不带其他参数的话,全部事件都会清理掉 原文地址:https://www.cnblogs.com/weiz

Jquery | 基础 | 事件的链式写法

$(".title").click(function () { $(this).addClass("curcol").next(".content").css("display", "block"); }); <!DOCTYPE html> <html> <head> <title>jQuery事件的链式写法</title> <script

9、网页制作Dreamweaver(jQuery基础:事件)

事件 定义:即当HTML中发生某些事(点击.鼠标移过等)的时候调用的方法 $(selector).action() 事件的触发有两种方法: 1.直接将发生的事写在<javascript>中 1 <script type="text/javascript"> 2 $(document).ready(function(){ 3 $("button").click(function(){ 4 $("p").hide(); 5 }

【jquery基础教程】jquery事件及操作大汇总

在学习Javascript语言中,有一个优秀的Javascript库是大家都会遇到的--jquery,今天小编汇总了jquery事件及操作,现在一起来看看jquery基础教程吧! 事件 bind()        向匹配元素附加一个或更多事件处理器 blur( )        触发.或将函数绑定到指定元素的 blur 事件 change()        触发.或将函数绑定到指定元素的 change 事件 click()        触发.或将函数绑定到指定元素的 click 事件 dblc

Jquery基础之事件操作

事件是用户操作时页面或页面加载时引发的用来完成javascript和HTML之间的交互操作.常见的元素点击事件.鼠标事件.键盘输入事件等,较传Javascript 相比JQuery增加并扩展了基本的事件处理机制,极大的增强了事件处理的能力. 一.DOM加载事件 页面加载完毕后浏览器会通过javascript为Dom元素加载事件,使用Javascript时候使用的是window.onload方法,而Jquery使用的是$(document).ready()方法,下表 展示两个事件的异同.    w

jQuery基础(鼠标事件,表单事件,键盘事件,自定义事件 篇)

1.jQuery鼠标事件之click与dbclick事件 方法一:$ele.click()(不带参数) <div id="test">点击触发<div> $("ele").click(function(){ alert('触发指定事件') }) $("#test").click(function(){ $("ele").click() //手动指定触发事件 });   方法二:$ele.click( h

【总结整理】JQuery基础学习---事件篇

jQuery鼠标事件之click与dbclick事件 用交互操作中,最简单直接的操作就是点击操作.jQuery提供了两个方法一个是click方法用于监听用户单击操作,另一个方法是dbclick方法用于监听用户双击操作.这两个方法的用法是类似的,下面以click()事件为例 使用上非常简单: 方法一:$ele.click() 绑定$ele元素,不带任何参数一般是用来指定触发一个事件,用的比较少 <div id="test">点击触发<div> $("el