Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >jQuery事件机制

jQuery事件机制

原创
作者头像
Qwe7
发布于 2022-04-16 06:04:11
发布于 2022-04-16 06:04:11
1.9K00
代码可运行
举报
文章被收录于专栏:网络收集网络收集
运行总次数:0
代码可运行

jQuery事件机制

JavaScript中已经学习过了事件,但是jQuery对JavaScript事件进行了封装,增加并扩展了事件处理机制。jQuery不仅提供了更加优雅的事件处理语法,而且极大的增强了事件的处理能力。

jQuery事件发展历程(了解)

简单事件绑定>>bind事件绑定>>delegate事件绑定>>on事件绑定(推荐)

简单事件注册

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    click(handler)            //单击事件
    mouseenter(handler)        //鼠标进入事件
    mouseleave(handler)        //鼠标离开事件

缺点:不能同时注册多个事件

bind方式注册事件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制

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

缺点:不支持动态事件绑定

delegate注册委托事件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制

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

缺点:只能注册委托事件,因此注册时间需要记得方法太多了

on注册事件

on注册事件(重点)

jQuery1.7之后,jQuery用on统一了所有事件的处理方法。

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

on注册简单事件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制

    // 表示给$(selector)绑定事件,并且由自己触发,不支持动态绑定。
    $(selector).on( "click", function() {});

on注册委托事件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制

    // 表示给$(selector)绑定代理事件,当必须是它的内部元素span才能触发这个事件,支持动态绑定
    $(selector).on( "click",'span', function() {});

on注册事件的语法:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    // 第一个参数:events,绑定事件的名称可以是由空格分隔的多个事件(标准事件或者自定义事件)
    // 第二个参数:selector, 执行事件的后代元素(可选),如果没有后代元素,那么事件将有自己执行。
    // 第三个参数:data,传递给处理函数的数据,事件触发的时候通过event.data来使用(不常使用)
    // 第四个参数:handler,事件处理函数
    $(selector).on(events,[selector],[data],handler);

事件解绑

unbind方式(不用)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    $(selector).unbind(); //解绑所有的事件
    $(selector).unbind("click"); //解绑指定的事件

undelegate方式(不用)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    $( selector ).undelegate(); //解绑所有的delegate事件
    $( selector).undelegate( 'click' ); //解绑所有的click事件

off方式(推荐)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    // 解绑匹配元素的所有事件
    $(selector).off();
    // 解绑匹配元素的所有click事件
    $(selector).off("click");

触发事件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    $(selector).click(); //触发 click事件
    $(selector).trigger("click");

jQuery事件对象

jQuery事件对象其实就是js事件对象的一个封装,处理了兼容性。

//screenX和screenY 对应屏幕最左上角的值

//clientX和clientY 距离页面左上角的位置(忽视滚动条)

//pageX和pageY 距离页面最顶部的左上角的位置(会计算滚动条的距离)

//event.keyCode 按下的键盘代码

//event.data 存储绑定事件时传递的附加数据

//event.stopPropagation() 阻止事件冒泡行为

//event.preventDefault() 阻止浏览器默认行为

//return false:既能阻止事件冒泡,又能阻止浏览器默认行为。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
jQuery基础--事件处理
简单事件绑定>>bind事件绑定>>delegate事件绑定>>on事件绑定(推荐)
eadela
2019/09/29
2.5K0
JQuery第三节
区别:html方法会识别html标签,text方法会那内容直接当成字符串,并不会识别html标签。
用户3461357
2019/08/02
8380
jquery第一次课的案例教程
js库:把一些常用到的方法写到一个单独的js文件,使用的时候直接去引用这js文件就可以了。 (animate.js、common.js)
张哥编程
2024/12/19
2260
JavaScript 学习-40.jQuery 绑定事件 on 和 bind
前言 jquery 有四种绑定事件的方式:on, bind, delegate,live。其中 live() 方法已被移除。 自 jQuery 版本 1.7 起,on() 方法是 bind()、live() 和 delegate() 方法的新的替代。 $(selector).off(type)为元素解除绑定的事件 on 绑定事件 基本语法 $(selector).on(event,childSelector,data,function) 参数 描述 event 必需。事件的类型一个或多个,由空格分隔多个事件
上海-悠悠
2022/06/07
1.1K0
JavaScript 学习-40.jQuery 绑定事件 on 和 bind
jQuery源码解析之jQuery.event.dispatch()
一、起源 jQuery.event.add()方法最终是用addEventListener绑定事件的:
进击的小进进
2019/09/05
8660
jQuery源码解析之你并不真的懂事件委托及target和currenttarget的区别
一、事件委托(委派) 含义: 在#A上绑定click事件,但是让#B触发click事件,相当于在 #B 上假绑定了 click 事件
进击的小进进
2019/09/05
7310
jQuery源码解析之你并不真的懂事件委托及target和currenttarget的区别
02-老马jQuery教程-jQuery事件处理
1. 绑简单事件 在DOM中DOM0级绑定事件的方式是直接给事件属性赋值,但是这样有个缺点就是每次指定的事件处理程序会把之前的覆盖掉。 jQuery简单绑定事件的方式,可以让我绑定多个事件处理程序跟D
老马
2018/01/05
2.9K0
jquery 事件绑定及取消 bind live delegate on one区别 (超详细且通俗易懂)
$(selector).bind(event,data,function,map)
坚毅的小解同志的前端社区
2022/11/28
2.5K0
jquery事件绑定
.bind()   为一个元素绑定一个元素处理程序。   .bind(eventType[,eventData],handler(eventObject))     eventType       一个包含一个或多个DOM事件类型的字符串,或自定义事件的名称。     eventData       一个对象,它包含的数据键值对映射将被传递给事件处理程序。     handler(eventObject)       每当事件
用户1197315
2018/01/19
3.8K0
Web前端JQuery入门实战案例
快速的,轻量级的,功能丰富的 js 库。动画(animation),ajax,DOM,更简单,容易使用的api。
达达前端
2019/07/03
4K0
02-老马jQuery教程-jQuery事件处理
根据文章内容总结摘要。
老马
2017/12/27
6.7K0
02-老马jQuery教程-jQuery事件处理
谁说你只是"会用"jQuery?
前言 套用上篇文章向zepto.js学习如何手动触发DOM事件 的开头??? 前端在最近几年实在火爆异常,vue、react、angular各路框架层出不穷,咱们要是不知道个双向数据绑定,不晓得啥是
IMWeb前端团队
2017/12/29
1.4K0
谁说你只是"会用"jQuery?
JQuery 入门 - 附案例代码
HTML入门与进阶以及HTML5 CSS JS-上 JS-下 jQuery Node.js + Gulp 知识点汇总 MongoDB + Express 入门及案例代码 Vue项目开发-仿蘑菇街电商APP
Twcat_tree
2023/02/20
14.1K0
JQuery 入门 - 附案例代码
jQuery 事件(三) 事件的绑定和解绑、对象的使用、自定义事件
之前学的鼠标事件,表单事件与键盘事件都有个特点,就是直接给元素绑定一个处理函数,所有这类事件都是属于快捷处理。翻开源码其实可以看到,所有的快捷事件在底层的处理都是通过一个”on”方法来实现的。jQuery on()方法是官方推荐的绑定事件的一个方法 基本用法:.on( events ,[ selector ] ,[ data ] ) 最常见的给元素绑定一个点击事件,对比一下快捷方式与on方式的不同
Yiiven
2022/12/15
4.3K0
【前端】详解JavaScript事件代理(事件委托)
事件代理(Event Delegation),又称之为事件委托。是JavaScript中常用绑定事件的常用技巧。
程序员洲洲
2024/06/11
8340
【前端】详解JavaScript事件代理(事件委托)
Python全栈之jQuery笔记
jQuery runnoob网址: http://www.runoob.com/jquery/jquery-tutorial.html jQuery API手册: http://www.runoob.com/manual/jquery/ jQuery笔记 笔记来源于: 传智播客的黑马程序员视频笔记. 菜鸟教程:http://www.runoob.com/ 自己的查询与整理. JS的不完美地方: 1. 代码比较麻烦,给多个元素添加事件需要遍历,可能还需要进行嵌套.
py3study
2020/01/19
5.6K0
jQuery中on()、bind()、live()、delegate()之间的区别
首先简述下回涉及到的几个知识点: DOM树 首先,可视化一个HMTL文档的DOM树是很有帮助的。一个简单的HTML页面看起来就像是这个样子:
Clearlove
2019/08/29
1.3K0
jQuery中on()、bind()、live()、delegate()之间的区别
第79天:jQuery事件总结(二)
       上一篇讲到jQuery中的事件,深入学习了加载DOM和事件绑定的相关知识,这篇主要深入讨论jQuery事件中的合成事件、事件冒泡和事件移除等内容。
半指温柔乐
2018/09/11
1.8K0
jQuery 事件绑定 和 JavaScript 原生事件绑定
jQuery 中提供了四种事件监听绑定方式,分别是 bind、live、delegate、on,
Krry
2018/09/10
6K0
jQuery 事件绑定 和 JavaScript 原生事件绑定
jQuery 事件
什么是事件 页面对不同访问者的响应叫做事件。 事件处理程序指的是当 HTML 中发生某些事件时所调用的方法。 常见 DOM 事件: 鼠标事件 键盘事件 表单事件 文档/窗口事件 click keypr
静默虚空
2018/01/05
3.1K0
相关推荐
jQuery基础--事件处理
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验