jQuery中创建实例与原型继承揭秘 - Web前端
作者:98wpeu发布时间:2026-06-26分类:网页前端技术浏览:4
导读:如newObject()、newdate()等等!(object有{},数组有[]这样的快捷方式,我们主要探讨new这种方式。)我们在使用JQuery时从来没有使用过ne...
如 new Object()、new date()等等!(object有{},数组有[]这样的快捷方式 ,我们主要探讨new这种方式。)
我们在使用JQuery时从来没有使用过new,他是不是用其他方法来生成实例呢?是不是没有使用prototype属性呢?事实上他都有使用,只是内部处理的非常巧妙,提高了使用的爽快度。我们来看看他的源码。
复制代码 代码如下:
funtion jQuery( selector, context){
return new jquery.fn.init( selector, context );
}
这里可以看出jquery是有构造函数的,也是用了new 创建实例的。那么JQuery.fn是什么呢?后面有个这样的处理:
复制代码 代码如下:
jQuery.fn = jQuery.PRototype={
init:function (){}
}
这样我们就明白了,jQuery的构造函数是他原型上的init方法,而不是function jQuery。这样的话每次调用$()他都会用jQuery原型上的init创建一个实例,那么新的问题来了。如果用init创建实例的话,这个对象继承的是init的prototype上的方法而不会继承jQuery prototype上的方法,那么他是怎么实现原型继承的呢?
jQuery.fn.init.prototype = jQuery.fn;
这里他有一个这样的处理,把jQuery.fn赋值给了jQuery.fn.init.prototype ,这一步很关键。我门看看这些是什么。
jQuery.fn是jQuery.prototype
jQuery.fn.init.prototype是jQuery.prototype.init.prototype
这个处理相当于
jQuery.prototype = jQuery.prototype.init.prototype
那么每当我们调用$()是,jQuery就会用new运算符调用他prototype上的init创建一个实例,这个由init创建实例会继承jQuery protype上的所有方法,并且这个实例的__proto__内部属性会指向jQuery的prototype属性。
另外我们注意到这个处理:
jQuery.fn = jQuery.prototype
这是他为了避免频繁的操作jQuery.prototype,所以用jQuery.fn缓存了jQuery.prototype。
这些的处理实在是非常巧妙,内部处理了实例创建不用使用者用new去生成实例,又非常漂亮的处理了prototype保证多实例共享方法减少资源开支。
我们在使用JQuery时从来没有使用过new,他是不是用其他方法来生成实例呢?是不是没有使用prototype属性呢?事实上他都有使用,只是内部处理的非常巧妙,提高了使用的爽快度。我们来看看他的源码。
复制代码 代码如下:
funtion jQuery( selector, context){
return new jquery.fn.init( selector, context );
}
这里可以看出jquery是有构造函数的,也是用了new 创建实例的。那么JQuery.fn是什么呢?后面有个这样的处理:
复制代码 代码如下:
jQuery.fn = jQuery.PRototype={
init:function (){}
}
这样我们就明白了,jQuery的构造函数是他原型上的init方法,而不是function jQuery。这样的话每次调用$()他都会用jQuery原型上的init创建一个实例,那么新的问题来了。如果用init创建实例的话,这个对象继承的是init的prototype上的方法而不会继承jQuery prototype上的方法,那么他是怎么实现原型继承的呢?
jQuery.fn.init.prototype = jQuery.fn;
这里他有一个这样的处理,把jQuery.fn赋值给了jQuery.fn.init.prototype ,这一步很关键。我门看看这些是什么。
jQuery.fn是jQuery.prototype
jQuery.fn.init.prototype是jQuery.prototype.init.prototype
这个处理相当于
jQuery.prototype = jQuery.prototype.init.prototype
那么每当我们调用$()是,jQuery就会用new运算符调用他prototype上的init创建一个实例,这个由init创建实例会继承jQuery protype上的所有方法,并且这个实例的__proto__内部属性会指向jQuery的prototype属性。
另外我们注意到这个处理:
jQuery.fn = jQuery.prototype
这是他为了避免频繁的操作jQuery.prototype,所以用jQuery.fn缓存了jQuery.prototype。
这些的处理实在是非常巧妙,内部处理了实例创建不用使用者用new去生成实例,又非常漂亮的处理了prototype保证多实例共享方法减少资源开支。
相关推荐
- JQUERY1.6 使用方法四 检测浏览器 - Web前端
- jQuery 阴影插件代码分享 - Web前端
- ASP.NET jQuery 实例7 通过jQuery来获取DropDownList的Text/Value属性值 - Web前端
- 基于Jquery插件开发之图片放大镜效果(仿淘宝) - Web前端
- 基于jquery点击自以外任意处,关闭自身的代码 - Web前端
- jQuery1.6 使用方法一 - Web前端
- 基于Jquery+Ajax+Json的高效分页实现代码 - Web前端
- JQuery1.6 使用方法三 - Web前端
- JQuery扩展插件Validate 2通过参数设置验证规则 - Web前端
- jQuery的.live()和.die() 使用介绍 - Web前端
- 网页前端技术排行
-
- 1【第六章】Foundation之按钮和下拉功能 - Web前端
- 2基于jquery的滚动条滚动固定div(附演示下载) - Web前端
- 3jQuery编写widget的一些技巧分享 - Web前端
- 4jQuery实例教程:制作网页中可折叠的面板 - Web前端
- 5在Mac/PC上远程调试iPhone/iPad上的网页 - Web前端
- 6分析Iconfont-阿里巴巴矢量常用图标库 - Web前端
- 7[Web前端]用javascript实现默认图片替代未显示的图片 - Web前端
- 8分享精心挑选的12款优秀jQuery Ajax分页插件和教程 - Web前端
- 9JS网页制作实例:标签云 - Web前端
- 最近发表
-
- WordPress随机显示特色图片插件:Random Post Thumbnails
- KeePass实现Chrome浏览器自动填充密码方法一
- LNMP一键包nginx 301强制跳转到https教程
- KeePass实现Chrome浏览器自动填充密码方法二
- #建站# 免费的VPS管理软件Xshell8/Xftp8中文版下载
- 使用Xshell 8连接VPS教程_电脑登录vps的方法
- WordPress评论界面添加烟花????效果
- 不同浏览器书签同步方案:坚果云+Floccus_详细使用教程
- iOS端KeePassXC客户端APP:Strongbox Password Safe
- 给WordPress评论中的Gravatar头像图片添加ALT属性


