我的编程空间,编程开发者的网络收藏夹
学习永远不晚

jQuery基本事件代码优化的示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

jQuery基本事件代码优化的示例分析

这篇文章主要介绍了jQuery基本事件代码优化的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

事件模型

说到事件,就要追溯到网景与微软的“浏览器大战”了。当时,事件模型还没有标准,两家公司的实现就是事实标准。网景在Navigator中实现了“事件捕获”的事件系统,而微软则在IE中实现了一个基本上相反的事件系统,叫做“事件冒泡”。这两种系统的区别在于当事件发生时,相关元素处理(响应)事件的优先权不同。

下面举例说明这两种事件机制的区别  。假设文档中有如下结构:

<div>       <span>           <a>...a>       span>   div>

因为这三个元素是嵌套的,所以单击了a,实际上也就单击了span和div  。换句话说,这三个元素都应该有处理单击事件的机会  。在事件捕获机制下,处理这个单击事件的优先次序是:div > span > a;而在事件冒泡机制下,处理这个单击事件的优先次序则是:a > span > div  。

后来,W3C的规范要求浏览器同时支持捕获和冒泡机制,并允许开发人员选择把事件注册到哪个阶段  。于是就有了下面这个注册事件的标准方法

target.addEventListener(type, listener, useCapture Optional );

其中:

type:字符串,表示监听的事件类型

listener:监听器对象(JavaScript函数),在指定事件发生时可以收到通知

useCapture:布尔值,是否注册到捕获阶段

在实际应用开发中,为了确保与IE(因为它不支持捕获)兼容,useCapture一般都指定为false(默认值也是false)  。换句话说,只把事件注册到冒泡阶段;对于上面那个简单的例子来说,响应顺序就是:a > span > div  。

冒泡的副作用

如前所述,IE的冒泡事件模型基本上成为了事实标准。但冒泡有一个副作用。

仍以前面的文档结构为例,假设它是界面中的一个菜单项,我们希望用户鼠标离开div时隐藏菜单。于是,我们给div注册了一个mouseout事件  。如果用户鼠标是从div离开的,那么一切正确  。而如果用户鼠标是从a或span离开的,问题就来了。因为由于事件冒泡,从这两个元素开始分派的mouseout事件都会传播到div,从而导致鼠标并没有离开div,菜单就提前隐藏了。

当然,冒泡的副作用不难避免  。比如,给div内部的每个元素都注册mouseout事件,并使用.stopPropagation()方法阻止事件进一步传播  。对于IE,就得将事件对象的cancelBubble属性设置为false,取消事件冒泡  。不过,这仍然回到自己处理浏览器不兼容性问题的老路上了  。

优化方案

为了避免冒泡的副作用,jQuery提供了mouseenter和mouseleave事件,就使用它们来代替mouseover和mouseout吧  。

下面这个摘自jQuery的内部函数withinElement,就是为mouseenter和mouseleave提供支持的  。翻译了一下注释,仅供大家参考  。

// 下面这个函数用于检测事件是否发生在另一个元素的内部    // 在 jQuery.event.special.mouseenter 和 mouseleave 处理程序中使用    var withinElement = function( event ) {        // 检测 mouse(over|out) 是否还在相同的父元素内        var parent = event.relatedTarget;           // 设置正确的事件类型        eventevent.type = event.data;           // Firefox 有时候会把 relatedTarget 指定一个 XUL 元素        // 对于这种元素,无法访问其 parentNode 属性        try {               // Chrome 也类似,虽然可以访问 parentNode 属性            // 但结果却是 null            if ( parent && parent !== document && !parent.parentNode ) {                return;            }               // 沿 DOM 树向上            while ( parent && parent !== this ) {                parentparent = parent.parentNode;            }               if ( parent !== this ) {                // 如果实际正好位于一个非子元素上面,那好,就处理事件                jQuery.event.handle.apply( this, arguments );            }           // 假定已经离开了元素,因为很可能鼠标放在了一个XUL元素上        } catch(e) { }    },

感谢你能够认真阅读完这篇文章,希望小编分享的“jQuery基本事件代码优化的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

jQuery基本事件代码优化的示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

jQuery实用的示例代码分析

本篇内容介绍了“jQuery实用的示例代码分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!★ 使用 jQuery 来切换样式表$("lin
2023-06-27

C#事件本质的示例分析

这篇文章将为大家详细讲解有关C#事件本质的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。C#事件本质上是对消息的封装,是IDE编程环境为了简化编程而提供的有用的工具。这个封装是在窗体过程中实现的。
2023-06-17

Ruby基础代码的示例分析

Ruby基础代码的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Ruby语言的学习和其他编程语言一样,首先要从基础开始。在这里我们为大家介绍了一下Ruby基础代码中
2023-06-17

SAP HUM事务代码 HUMAT的示例分析

这篇文章给大家介绍SAP HUM事务代码 HUMAT的示例分析,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。SAP HUM事务代码 HUMAT SAP菜单中,该事务代码在这里:1)如下的inbound delivery
2023-06-05

JavaScript代码优化的技巧实例分析

本篇内容主要讲解“JavaScript代码优化的技巧实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript代码优化的技巧实例分析”吧!写在前面想要做到JavaScript的代
2023-07-02

优化算法库DEAP的粒子群优化算法(PSO)示例代码分析

之前使用优化算法库DEAP做遗传算法(Genetic Optimization),最近在研究粒子群优化算法(PSO)发现DEAP也提供支持;对原代码做了分析,之后会尝试用于交易策略参数优化。首先关于粒子群优化算法(PSO),这个算法的介绍很
2023-06-02

js的onload事件及初始化按钮事件示例代码

onload事件当一个页面或是一张图片加载完成时被触发,在body上不仅可以用onload,而且还支持多个HTML标签.用法如下
2022-11-15

编程热搜

目录