jQuery中创建实例与原型继承揭秘
来源:互联网 发布:新浪ip反查域名 编辑:程序博客网 时间:2024/06/16 15:49
断断续续用jquery两年了,最近一般的jquery应用已经满足自己的求知欲望了,只能找jquery源码来“泄欲”了,今天先从创建jquery对象说起吧
在普通情况下我们要用原生类、或者自定义类创建实例要用new运算符,使构造函数创建一个实例,并且实例继承构造器prototype上的所有公有方法
如 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中创建实例与原型继承揭秘
- jQuery中创建实例与原型继承揭秘
- jQuery中创建实例与原型继承揭秘
- jQuery创建实例与原型继承揭秘
- js 创建对象与原型链继承
- JS原型继承实例
- 原型链继承实例
- 类继承与原型继承
- 继承与原型链
- 原型对象与继承
- JavaScript原型与继承
- 原型与继承
- 原型链与继承
- 原型与继承
- 继承与原型链
- JavaScript原型与继承
- 继承与原型链
- 继承与原型链
- SQLite指南(2) -- 帮助及编译SQLite
- Hibernate读书笔记-----Hibernate的关联映射之N-1关联映射
- SQLite指南(3) - 5分钟了解熟悉SQLite
- Android动画学习笔记
- itunes相关
- jQuery中创建实例与原型继承揭秘
- SQLite指南(4) - FAQ列表(important)
- 错误:无法访问android.app.Activity 找不到android.app.Activity 的解决方式
- SQLite指南(5) - PRAGMA命令用法(完整)
- Kanban的五个属性
- 例题5.4.2
- SQLite指南(6)-处理database is locked的方法
- ubuntu下安装JDK过程
- supervlan的配置