位置: 编程技术 - 正文

jQuery-1.9.1源码分析系列(十)事件系统之事件包装(jquery3.2.1)

编辑:rootadmin

推荐整理分享jQuery-1.9.1源码分析系列(十)事件系统之事件包装(jquery3.2.1),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery代码库,jquery1.12.4,jquery3.2.1,jquery源码视频,jquery原理和实现步骤,jquery1.8,jquery1.8,jquery原理和实现步骤,内容如对您有帮助,希望把文章链接给更多的朋友!

在上篇文章给大家介绍了jQuery-1.9.1源码分析系列(十)事件系统之事件体系结构,本篇继续给大家介绍jquery1.9.1源码分析系列相关知识,具体内容请看下文吧。

首先需要明白,浏览器的原生事件是只读的,限制了jQuery对他的操作。举个简单的例子就能明白为什么jQuery非要构造一个新的事件对象。

  在委托处理中,a节点委托b节点在a被click的时候执行fn函数。当事件冒泡到b节点,执行fn的时候上下文环境需要保证正确,是a节点执行了fn而非b节点。如何保证执行fn的上下文环境是a节点的:看源码(红色部分)

使用了apply将执行函数的上下文替换成了a节点(matched.elem)。还有一点args[0]即是事件对象event。又如何保证event是a节点的事件的?这就是event.currentTarget这个重要的属性的功能,所以在执行apply之前还做了一步操作

直接更改事件对象的currentTarget属性,这在浏览器本地事件是做不到的。所以才有了基于本地事件构造jQuery的事件对象。

事件分两种:鼠标事件和键盘事件(不知道触摸事件何时能加进来)。看一下这两者的详细属性

  

  其中有些是浏览器自己的,非W3C标准的。jQuery将事件属性分为三块

鼠标和键盘事件共同拥有的属性jQuery.event.props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" ")

键盘事件专有的属性jQuery.event.keyHooks.props: "char charCode key keyCode".split(" ")

鼠标事件专有的属性jQuery.event.mouseHooks.props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" ")

a. 构造新的事件对象jQuery.event.fix(originalEvent)

构造新的事件对象分三步完成

第一步,使用到event = new jQuery.Event( originalEvent ),构造新事件对象(不明白new的作用的请点击这里),并在创建事件的时候加上isDefaultPrevented、originalEvent、type 、timeStamp和事件已经被修正过的标记(优化使用,避免不必要的处理)。jQuery.Event(src, props)的源码如下

jQuery-1.9.1源码分析系列(十)事件系统之事件包装(jquery3.2.1)

第一步构造后的事件对象

  

第二步,分辨出当前事件是那种事件,然后将对应的属性一一从浏览器本地事件originalEvent中拷贝过来

第三步,相关属性的兼容处理

最后那句代码针对鼠标事件和键盘事件做兼容适配处理。

  fixHook.filter可能是jQuery.event.keyHooks.filter

或这jQuery.event.mouseHooks.filter

构建完成的最新事件对象如下(以鼠标事件为例)

  

原生的事件保存在了originalEvent中,target保存了目标节点(委托的节点、事件源),其他信息略过

b. 重载事件方法

  构建新的事件对象event = new jQuery.Event( originalEvent )时,事件会继承jQuery.event.prototype中的方法。来看一看有哪些方法

  

  前面分析了jQuery.event.prototype中重载了stopPropagation方法的作用:处了调用事件对象的阻止冒泡方法以外,还有一个作用就是被委托节点有多个被委托事件处理等待处理时,其中一个事件调用了event.stopPropagation()将阻止后续事件处理的执行。点击这里搜索关键字查看

  preventDefault函数也是有类似的作用。preventDefault函数中增加了这段代码

在触发事件trigger函数和模拟冒泡simulate函数中都会根据isPropagationStopped()判断是否要执行DOM节点的默认操作。源码如下

isImmediatePropagationStopped是stopPropagation特殊用法,isImmediatePropagationStopped会直接阻止掉当前的处理和后面等待执行的事件处理,而stopPropagation会执行完当前的处理,然后阻止后面等待执行的事件处理。

源码如下

标签: jquery3.2.1

本文链接地址:https://www.jiuchutong.com/biancheng/370556.html 转载请保留说明!

上一篇:Jquery ajax基础教程

下一篇:jQuery实现分隔条左右拖动功能(用jquery实现隔行变色)

  • 亏损企业需要计提递延所得税资产吗
  • 购买产品再出售怎么入账
  • 企业贷款合同签订后多久放款
  • 销售货物和服务流程 事前检查单上
  • 已经缴纳的税款怎么做账
  • 固定资产后续支出可以计入哪些费用
  • 财务专用章的重要性
  • 股东经济性质怎么填
  • 手撕发票怎么领取需要什么证件
  • 总分机构账务处理
  • 个人购买商铺如何缴税
  • 银行存款转存利息一样吗
  • 长期股权投资会减值损失吗
  • 员工内部跑步活动费用怎么做分录?
  • 法人的往来款可以转为实收资本吗?
  • 被代持股份怎么退出
  • 药品回扣2021
  • 理财产品分红怎么入账
  • 周转材料低值易耗品
  • 小规模纳税人开专票税率是1%还是3%
  • 增值税普通发票怎么开
  • 审计费用收取标准的2020
  • 银行承兑汇票加工费合同
  • 招商引资政府返税政策不兑现
  • 增值税税额转出申报怎么填写
  • 公司帮别人代缴社保
  • 预付股权转让款如何处理
  • 个税扣缴端如何删除员工信息
  • 房地产企业闲置土地怎么处理
  • 应收账款坏账准备是信用减值损失还是资产
  • 公益性捐赠包括向脱贫地区捐赠吗
  • mac输入法打不出简体
  • 建筑业销项税和进项税计算
  • 会计差错更正处理
  • php数组函数输出《咏雪》里有多少"片"字
  • opware12.exe - opware12进程是什么文件 有什么用
  • ospf区域间路由和区域内路由
  • 影视公司纳税标准
  • 监狱劳教企业是国企吗
  • Cookie 的 SameSite 属性
  • 解决掉发的有效方法
  • 二手车价格网站
  • 个体工商户属于灵活就业人员吗
  • 公积金会计分录怎么处理2019
  • 固定资产报废清理怎么做账务处理的
  • python模块的扩展名
  • dedecms插件
  • 公司茶水间管理规定
  • 开专票明细太多怎么开
  • 受托代销商品的成本结转
  • 运输发票抵扣税额怎么算
  • 外购商品用于宣传需要缴纳增值税吗
  • 给客户的客户开普票算不算虚开
  • 实收资本印花税属于什么税目
  • 收入费用表本期盈余与资产负债表不一致
  • 什么是残保金减免政策
  • 公司有美金账户如何做账
  • 甲方代付农民工工资谁报个税
  • 坏账准备确认坏账
  • 利润表增加,资产负债表减少怎么回事
  • 会计账簿的设计要与会计报表相衔接 ()X
  • windows常用功能
  • 联想lenovo thinkpad c13 yoga
  • DWHeartbeatMonitor.exe进程是什么意思 DWHeartbeatMonitor是安全的进程吗
  • win10自带地图打不开
  • 24个方法
  • win10如何删除右键菜单选项
  • shell 子函数
  • win8适用的pr
  • linker command failed with exit code 1 (use -v to see invocation)
  • 在动画制作中一般默认帧数选择为
  • 批处理清空文本内容
  • unity怎么设置多个关卡
  • js中面向对象编程
  • 安徽税务网上申报领取发票
  • 工会经费按年还是季度申报
  • 2006年发生哪一些大案
  • 重庆市国税网官方网站
  • 北京地税局上班时间查询
  • 江苏国税电子国税局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设