位置: 编程技术 - 正文

谈一谈jQuery核心架构设计(jquery的核心函数)

编辑:rootadmin

推荐整理分享谈一谈jQuery核心架构设计(jquery的核心函数),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery概述,jquery的核心理念,简述jquery,jquery的三大功能,jquery的原理,jquery概述,jquery的设计思想,简述jquery,内容如对您有帮助,希望把文章链接给更多的朋友!

jQuery对于大家而言并不陌生,因此关于它是什么以及它的作用,在这里我就不多言了,而本篇文章的目的是想通过对源码简单的分析来讨论 jQuery 的核心架构设计,以及jQuery 是如何利用javascript中的高级特性来构建如此伟大的javascript库。

1 初识jQuery

从核心功能来看,jQuery仅仅做了一件简单而又平凡的事:查询。它的语法如此简洁明了,以致于很多人在不知道javascript是什么的时候就已经会用jQuery了,用一个词形容就是:大道至简。 从设计层面来看,我们可以将jQuery提供方法分为两大类:静态方法和实例方法。静态方法就是直接通过$访问的方法,这些方法一般不对dom元素操作,而是提供了一些常用的工具,比如ajax请求、以及对字符串的一些常用操作,除此之外,jQuery还提供了对自身的扩展机制,你可以通过extend方法来编写你需要的组件。而实例方法和静态方法不一样,它是用来对jQuery查询的DOM元素进行操作,jQuery执行$()会构建一个jQuery对象,这个对象以数组的方法存储查询出的所有DOM元素,然后在这个对象的原型链上实现了对这些DOM操作的方法,比如each()方法就是用来遍历每一个DOM元素的。你可能会注意到,我刚说这个对象“以数组的方式”存储,那就是说,jQuery构建的这个对象不是数组,那这个对象到底是什么? 其实这个对象就是jQuery的核心,也被称作“jQuery对象”。因此,本文的重点就是对jQuery对象进行分析和讨论。

2 jQuery对象

一般情况下,我们会这样使用jQuery:

$('div')执行完后回返回一个jQuery对象,each()方法是对这个对象中的DOM元素进行遍历,我们先看看$('div')的执行过程(本文源码摘自jQuery 3.0):

这个方法就是$('div')的入口方法,$是jQuery的简写,就相当于jQuery('div') ,可以看出,这个方法只做了一件事,那就是返回jQuery.fn.init()函数的实例对象,那jQuery.fn.init 又是什么呢,我们再看下面的代码:

jQuery.fn.init和init引用了同一个方法,这个方法根据selector查询出符合条件的DOM元素,并返回,可你会发现,返回的是this,这个this是什么呢?我们待会分析,先看下面的这句话:

谈一谈jQuery核心架构设计(jquery的核心函数)

init.prototype = jQuery.fn;这句话是什么意思呢,这句话是让init方法的prototype对象指向了jQuery.fn对象,那jQuery.fn又是什么鬼? 我们继续看代码:

为了节省篇幅,我省略了其中一些代码,从这里可以看出,jQuery.fn 其实就是jQuery的原型对象,这个原型对象中定义了一些对this对象进行操作的方法。到这里,你是不是感觉到有点绕,不要着急,我们来梳理一下思路:jQuery首先定义了一个init方法,然后在init的原型对象prototype上定义了一系列操作方法。最后将init方法的实例对象返回。所以上面的过程可以简化如下(伪代码表示):

那么问题来了,jQuery.fn中的方法为什么不直接定义在init的prototype上,而要定义在jQuery的原型对象上?

其实,这样做的目的是为了提高jQuery的查询效率,如果直接定义在init的prototype对象上,那么每执行一次查询,就会在内存中创建这样一个庞大的prototype对象,而如果把这个对象定义在jQuery的prototype上,在jQuery加载时,这个对象就会被初始化并一直存在于内存中,以后每次执行$()时,只需要将init中的prototype指向这个对象就可以了,而不用每次都去创建一遍相同的对象。

我们再来看看 init 函数中返回的 this 到底是什么,我在之前的博客中讲过,函数中的this总是指向运行期的调用者,那init的调用者是谁呢?在上面代码中似乎找不到调用者,这时我们就需要深入的理解new运算符的运行机制了,借用我之前在博客中对new运算符的描述,我们对new init()的执行过程进行如下分解:

如果对new的运行机制不理解的请参考博文: javascript new 的运行机制

从上述分解过程可以看出,javascript在通过 new 来创建一个实例对象的时候,会先创建了一个普通对象obj,然后将obj的内部属性__proto__指向了init的原型对象,因此obj的原型链将被改变,而第3步使用call方法调用init(),所以init中的this指的就是这里的obj对象。

init()执行以后,会将匹配到的所有DOM对象以数组的方式存储到this对象中并返回,也就是返回了obj对象,而new运算符最终也会将这个 obj 对象返回以作为新的实例对象。所以new运算符返回的这个实例对象具备两个特点:一是包含了DOM查询结果集,二是其原型链继承了init的prototype,而 init 的 prototype 又指向了jQuery.fn对象,因此实例对象也具备了这些操作方法。

jQuery每执行一次查询就会创建一个jQuery对象,而在同一个应用程序中,所有jQuery对象都会共享同一个jQuery原型对象。因此,jQuery对象不仅包含了DOM查询结果集,还继承了jQuery原型对象上的操作方法。这样,你就可以在查询后直接调用方法来操作这些DOM元素了。这就是jQuery的核心架构设计,简单、方便、实用!

如果你还不理解上面的讲解,不要着急,我按照jQuery的设计思路写了一个完整的小项目jDate,你可以对比着理解!jDate项目已上传至GitHub,你可以点击这里查看完整代码:jDate ,如有不同见解,欢迎讨论!

3 jQuery 的缺陷

通过对jQuery的核心架构分析,我们会发现,每执行一次查询,jQuery就要在内存中构建一个复杂的jQuery对象,虽然说每个jQuery对象都共享同一个jQuery原型,但jQuery的查询过程远比你想象的要复杂,它既要考虑各种不同的匹配标识,同时又要考虑不同浏览器的兼容性。因此,如果你只是对DOM做一些简单的操作,建议使用原生方法 querySelector 替代 jQuery,不过在使用原生方法时,对于不同的应用场景你可能要做一些兼容性的工作,你要学会取舍,不要过度依赖jQuery!

标签: jquery的核心函数

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

上一篇:jQuery实现的多滑动门,多选项卡效果代码(jquery 滑动显示)

下一篇:jQuery简单实现提交数据出现loading进度条的方法(jquery detach)

  • 增值税价外费用开票内容
  • 对方给我公司开的红字发票如何查询
  • 所得税申报表营业成本填什么数据
  • 采购人员的差旅费计入采购成本吗?
  • 处置资产开啥发票
  • 什么情况下要交土地出让金
  • 可转换债券含义
  • 台港澳与境内合资企业和央企哪个好
  • 销售商品,提供服务以及从事其他经营活动
  • 辅导期纳税人会计处理
  • 成品油增值税抵减政策
  • 用外购存货投资分录怎么写?
  • 政府补贴转给其他公司
  • 营业外收入税前列支
  • 会务费抵扣限额
  • 需要自己到税务局自行申报个人所得税的纳税人有哪些?
  • 白银及其制品出自哪里
  • 原材料和加工费能分着开票么
  • PHP:oci_result()的用法_Oracle函数
  • 一般纳税人资质证明文件去哪打印
  • PHP中使用全局变量来接受表单中提交的数据
  • php有很多流行的mvc框架,这些框架可以
  • mac os常用快捷键
  • 老大心态是什么意思
  • 销售安装费的账务处理
  • PHP:Memcached::setOption()的用法_Memcached类
  • 手机电脑排行
  • 社保挂靠会计处理?
  • 产供销一体化什么意思
  • 行政事业单位会计科目一览表
  • 原材料明细账有记税吗
  • 黑暗的树荫
  • 收到承兑汇票怎么签收
  • vue自定义弹窗带有遮罩层
  • thinkphp怎么用
  • 2022年微信小程序游戏
  • php使用正则表达式检测是否包含非数字
  • python中datetime用法
  • Windows OpenGL ES 图像曝光度调节
  • MySQL中Nested-Loop Join算法小结
  • 预算收入支出
  • 个税申报逾期罚款怎么算
  • 企业法人需要本人到场吗
  • java实现打印
  • 销项发票属于哪个科目
  • 什么是稳岗补贴呢
  • 负商誉的分录
  • 土地出让金返还比例是多少
  • 预提成本和冲回成本金额不一致情况说明
  • 管理费用收入缴纳增值税吗
  • 收到免税发票会计分录
  • 预收账款的金额是什么
  • 工资计入会计科目
  • 产品质量认证费用属于什么成本
  • 会计师事务所工作怎么样
  • 房租费计提如何入账
  • 委托加工企业的账务处理
  • mysql rand整数
  • 当你感觉到你的win2000运行速度明显减慢
  • win10系统怎么修改用户名称
  • centos6.7安装图形界面教程
  • linux下32位机与64位机基本数据类型长度区别介绍
  • win10系统怎么设置不锁屏和休眠
  • msmpeng.exe是什么进程
  • 预装win7旗舰版
  • win8隐藏的文件夹怎么找出来
  • window10光驱不能用了
  • 将目录下的文件和文件夹按类型排序
  • win10安装node.js
  • 深入php面向对象、模式与实践第5版 电子书
  • 网页编辑器手机版
  • python常用操作运算符
  • javascript要怎么学
  • javascript 日期运算
  • 关于增值税纳税人的规定,下列说法正确的是
  • 江西省医保卡缴费
  • 收到免税的苗木发票怎么做账
  • 郑州市管城区地图范围
  • 龙岗税务分局管辖范围
  • 北京企业所得税汇算清缴时间
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设