8、jQuery-常用事件

一、事件API

jQuery对象的核心事件方法,核心事件函数,主要用于为元素的任意事件(包括自定义事件)添加、取消、触发绑定的一个或多个事件处理函数

二、on()

1、说明

在被选元素及子元素上添加一个或多个事件处理程序。
自 jQuery 版本** 1.7 起**,on() 方法是 bind()、live() 和 delegate() 方法的新的替代品。该方法给 API 带来很多便利,我们推荐使用该方法,它简化了 jQuery 代码库。

2、语法

$("selector").on(event,childSelector,data,function,map)

3、参数

参数 说明
event(必要) 规定要从被选元素移除的一个或多个事件或命名空间。由空格分隔多个事件值。必须是有效的事件
data(可选) 规定只能添加到指定的子元素上的事件处理程序(且不是选择器本身,比如已废弃的 delegate() 方法)
function(可选) 规定当事件发生时运行的函数。
map ({event:function, event:function, ...}),包含要添加到元素的一个或多个事件,以及当事件发生时运行的函数。

4、栗子

html代码

<p>盘我<p>

jq代码

$("p").on("click",function(){
    alert("给p元素添加单击事件");
});
$("p").on({
  click:function{
    alert("一次绑定多个事件--->点击事件")
  }
  dblclick:function{
        alert("一次绑定多个事件--->双击事件")
  }
});

三、移除事件

1、说明

off()方法通常用于移除通过on()方法添加的事件处理程序。自 jQuery 版本 1.7 起,off() 方法是 unbind()、die() 和 undelegate() 方法的新的替代品。

2、语法

$("select").off(events,select, function(event e))

3、参数

参数 说明
events(可选) 一个或多个空格分隔的事件类型
select(可选) 字符串类型 一个选择器,当绑定事件处理程序时匹配最初传递给 .on()的那个
function 以前附加的事件处理函数,或特殊值false

4、栗子

html代码

<button id="add">点击事件</button>
<button id="off">移除事件</button>

qj代码

$("#off").on("click",function(){alert("点击事件")})
// 移除当前元素的所有事件
$("#add").off();
$("#off").click(function () {
  $("#add").off("click", function(){
        alert("移除事件")
  })
});
$("#off").click(function () {
  $("body").off("click","#off" ,function(){
        alert("通过父类元素移除指定事件")
  })
});

四、click()

1、说明

触发每一个匹配元素的click事件。这个函数会调用执行绑定到click事件的所有函数。

2、语法

$("selector").click(data,fn);

3、参数

参数 说明
data fn处理函数的参数或数据。
fn 在每一个匹配元素的click事件中绑定的处理函数。

4、栗子

html代码

jq代码

五、change()

1、说明

当元素的值发生改变时,会发生change事件。该事件仅适用于文本域(text field),以及 textarea 和 select 元素。当用于 select 元素时,change事件会在选择某个选项时发生。当用于 text field 或 text area 时,该事件会在元素失去焦点时发生

2、语法

$("selector").change(data,fn);

3、参数

参数 说明
data fn处理函数的参数或数据。
fn 在每一个匹配元素的keydown事件中绑定的处理函数。

4、栗子

html代码

<input type='text'>

jq代码

$(":text").change(function(){
    $(this).css("background-color","#FFFFCC");
});

六、mouseover() mouseout()

1、说明

当鼠标指针位于元素上方时,会发生mouseover事件。该事件大多数时候会与mouseout事件一起使用。
当鼠标指针从元素上移开时,发生mouseout事件。该事件大多数时候会与mouseover事件一起使用。
请使用hover事件代替

2、语法

$("selector").mouseover(data,fn);
$("selector").mouseout(data,fn);

3、参数

参数 说明
data fn处理函数的参数或数据。
fn 在每一个匹配元素的keydown事件中绑定的处理函数。

七、hover

1、说明

是mouseover和mouseout的合成事件

2、语法

$("selector").hover(inFunction,outFunction)

3、参数

参数 描述
inFunction 必需。规定 mouseover 事件发生时运行的函数。
outFunction 可选。规定 mouseout 事件发生时运行的函数。

4、栗子

html代码

<a href="#">首页<>

jq代码

// 给a元素添加hover事件
$("a").hover(
  function () {
    $(this).css('color','red')
  },
  function () {
    $(this).css('color','black')
  }
);

八、select()

1、说明

当 textarea或文本类型的 input 元素中的文本被选择时,会发生 select 事件。

2、语法

$("selector").$(selector).select(function)

3、参数

参数 说明
function(可选) 当发生 select 事件时运行的函数。

4、栗子

html代码

<input type="text" value="请输入内容"/>
<input type="text" value="测试内容"/>
<div></div>

qj代码

$(":input").select( function () {
     $("div").text("文本框被选中");
});

九、submit()

1、说明

当提交表单时,会发生 submit 事件。该事件只适用于表单元素。

2、语法

$("selector").submit(data,fn);

3、参数

参数 说明
data fn处理函数的参数或数据。
fn 在每一个匹配元素的submit事件中绑定的处理函数。

4、栗子

html代码

<form>
  <input type='text'>
  <input type='password'>
</form>

qj代码

$("form").submit(function () {
  alert("表单提交事件");
  return false;
} );

十、支持的事件汇总

1、元素事件

方法 版本 描述
bind() 1.0 为元素的任意事件绑定事件处理函数。
one() 1.1 为元素(或后代元素)的任意事件绑定一次性的事件处理函数。
live() 1.31.71.9 为元素(或后代元素)的任意事件绑定事件处理函数。
delegate() 1.4.2 为元素(或后代元素)的任意事件绑定事件处理函数。
on() 1.7 为元素(或后代元素)的任意事件绑定事件处理函数。
unbind() 1.0 bind()的逆操作,解除元素任意事件绑定的处理函数。
die() 1.31.71.9 live()的逆操作,解除元素(或后代元素)任意事件绑定的处理函数。
undelegate() 1.4.2 delegate()的逆操作,解除元素(或后代元素)任意事件绑定的处理函数。
off() 1.7 on()的逆操作,解除元素(或后代元素)任意事件绑定的处理函数。
trigger() 1.0 手动触发元素上的任意事件。
triggerHandler() 1.2 手动触发元素上的任意事件,但不会触发元素的默认事件行为,也不支持事件冒泡。

2、浏览器事件——主要用于浏览器Window对象的事件

resize() 1.0 为resize事件绑定处理函数,或触发该事件。该事件会在浏览器窗口大小被改变时触发。
scroll() 1.2 为scroll事件绑定处理函数,或触发该事件。该事件会在元素滚动(滚动条有变化)时触发。

3、表单事件——主要用于表单元素的事件

focus() 1.0 为focus事件绑定处理函数,或触发该事件。该事件会在元素获得焦点时触发。
blur() 1.0 为blur事件绑定处理函数,或触发该事件。该事件会在元素失去焦点时触发。
focusin() 1.0 为focusin事件绑定处理函数。该事件会在元素获得焦点时触发。
focusout() 1.0 为focusout事件绑定处理函数。该事件会在元素失去焦点时触发。
change() 1.0 为change事件绑定处理函数,或触发该事件。该事件会在元素的值被更改时触发。
select() 1.0 为select事件绑定处理函数,或触发该事件。该事件会在元素的用户输入被选中时触发。
submit() 1.0 为submit事件绑定处理函数,或触发该事件。该事件会在表单被提交时触发。

4、键盘事件——与键盘按键操作相关的事件

keydown() 1.0 为keydown事件绑定处理函数,或触发该事件。该事件会在键盘按键被按下时触发。
keypress() 1.0 为keypress事件绑定处理函数,或触发该事件。该事件会在键盘按键被按下时触发。
keyup() 1.0 为keyup事件绑定处理函数,或触发该事件。该事件会在键盘按键被按下并释放时触发。

5、鼠标事件——与鼠标按键操作相关的事件

click() 1.0 为click事件绑定处理函数,或触发该事件。该事件会在点击鼠标按钮时触发。
dblclick() 1.0 为dblclick事件绑定处理函数,或触发该事件。该事件会在双击鼠标按钮时触发。
toggle() 1.01.81.9 为click事件绑定两个以上的处理函数,每次触发事件时将轮流切换执行其中的单个函数。
hover() 1.0 为hover事件绑定处理函数。该事件会在鼠标进入或离开元素时触发。
mouseenter() 1.0 为mouseenter事件绑定处理函数。该事件会在鼠标进入元素时触发。
mouseleave() 1.0 为mouseleave事件绑定处理函数。该事件会在鼠标离开元素时触发。
mouseover() 1.0 为mouseover事件绑定处理函数。该事件会在鼠标进入元素时触发。
mouseout() 1.0 为mouseout事件绑定处理函数。该事件会在鼠标离开元素时触发。
mousedown() 1.0 为mousedown事件绑定处理函数。该事件会在鼠标按钮被按下时触发。
mouseup() 1.0 为mouseup事件绑定处理函数。该事件会在鼠标按钮被按下并释放时触发。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,185评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,652评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,524评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,339评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,387评论 6 391
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,287评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,130评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,985评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,420评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,617评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,779评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,477评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,088评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,716评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,857评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,876评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,700评论 2 354

推荐阅读更多精彩内容

  •   JavaScript 与 HTML 之间的交互是通过事件实现的。   事件,就是文档或浏览器窗口中发生的一些特...
    霜天晓阅读 3,490评论 1 11
  • 一:认识jquery jquery是javascript的类库,具有轻量级,完善的文档,丰富的插件支持,完善的Aj...
    xuguibin阅读 1,710评论 1 7
  • 22、JQ的基础语法、核心原理和项目实战 jQ的版本和下载 jQuery版本 1.x:兼容IE6-8,是目前PC端...
    萌妹撒阅读 1,746评论 0 0
  • 本篇博客源地址 总结: 鼠标事件 1.click与dbclick事件ele.click()ele.click(ha...
    ZombieBrandg阅读 674评论 0 1
  • 总结: 鼠标事件 1.click与dbclick事件$ele.click()$ele.click(handler(...
    阿r阿r阅读 1,605评论 2 10