1.jquery源码分析-无 new 构造
来源:互联网 发布:桌面规划软件 编辑:程序博客网 时间:2024/06/05 02:47
http://www.cnblogs.com/coco1s/p/5261646.html
http://www.cnblogs.com/SheilaSun/p/4779895.html
// 用一个函数域包起来,就是所谓的沙箱// 在这里边 var 定义的变量,属于这个函数域内的局部变量,避免污染全局// 把当前沙箱需要的外部变量通过函数参数引入进来// 只要保证参数对内提供的接口的一致性,你还可以随意替换传进来的这个参数(function(window, undefined) { // jQuery 代码})(window);
无 new 的构造方式(function( window, undefined ) { var jQuery = (function() { // 构建jQuery对象 var jQuery = function( selector, context ) { return new jQuery.fn.init( selector, context, rootjQuery ); } // jQuery对象原型 jQuery.fn = jQuery.prototype = { constructor: jQuery, init: function( selector, context, rootjQuery ) { // something to do } }; // Give the init function the jQuery prototype for later instantiation jQuery.fn.init.prototype = jQuery.fn; // 合并内容到第一个参数中,后续大部分功能都通过该函数扩展 // 通过jQuery.fn.extend扩展的函数,大部分都会调用通过jQuery.extend扩展的同名函数 jQuery.extend = jQuery.fn.extend = function() {}; // 在jQuery上扩展静态方法 jQuery.extend({ // something to do }); // 到这里,jQuery对象构造完成,后边的代码都是对jQuery或jQuery对象的扩展 return jQuery; })(); window.jQuery = window.$ = jQuery; })(window);
大部分人初看 jQuery.fn.init.prototype = jQuery.fn 这一句都会被卡主,很是不解。但是这句真的算是 jQuery 的绝妙之处。理解这几句很重要,分点解析一下:
1)首先要明确,使用 $(‘xxx’) 这种实例化方式,其内部调用的是 return new jQuery.fn.init(selector, context, rootjQuery) 这一句话,也就是构造实例是交给了 jQuery.fn.init() 方法取完成。
2)将 jQuery.fn.init 的 prototype 属性设置为 jQuery.fn,那么使用 new jQuery.fn.init() 生成的对象的原型对象就是 jQuery.fn ,所以挂载到 jQuery.fn 上面的函数就相当于挂载到 jQuery.fn.init() 生成的 jQuery 对象上,所有使用 new jQuery.fn.init() 生成的对象也能够访问到 jQuery.fn 上的所有原型方法。
3)也就是实例化方法存在这么一个关系链
- jQuery.fn.init.prototype = jQuery.fn = jQuery.prototype ;
- new jQuery.fn.init() 相当于 new jQuery() ;
- jQuery() 返回的是 new jQuery.fn.init(),而 var obj = new jQuery(),所以这 2 者是相当的,所以我们可以无 new 实例化 jQuery 对象。
- 构造函数有return值怎么办?
构造函数里没有显式调用return时,默认是返回this对象,也就是新创建的实例对象。
当构造函数里调用return时,分两种情况:
1.return的是五种简单数据类型:String,Number,Boolean,Null,Undefined。
这种情况下,忽视return值,依然返回this对象。
2.return的是Object
这种情况下,不再返回this对象,而是返回return语句的返回值。
0 0
- 1.jquery源码分析-无 new 构造
- jquery无new构造
- 分析一:jQuery的无new构建
- javaScript的无new构建,jquery源码对象构建方法
- jQuery源码分析7--分离构造器
- jquery 无new 思想
- jQuery源码分析-构造jQuery对象-工具函数
- jquery-1.91.源码分析-2 jquery对象构造
- jQuery源码分析-03构造jQuery对象-工具函数
- jQuery源码分析笔记-构造jQuery对象(三)
- jQuery源码分析(版本1.6.1)___构造jQuery对象-源码结构和核心函数
- jQuery源码分析-构造jQuery对象-源码结构和核心函数
- jQuery源码分析-03构造jQuery对象-源码结构和核心函数
- jQuery源码分析-03构造jQuery对象-源码结构和核心函数
- jQuery源码分析-03构造jQuery对象-源码结构和核心函数
- [ jQuery ] jQuery 源码分析!
- jQuery源码分析(版本1.6.1)___构造jQuery对象-工具函数
- jQuery源码分析(版本1.6.1)___构造jQuery对象-Sizzle工作原理
- PAT1017. Queueing at Bank (25)
- int转String的三种方法性能分析
- Download ERS-1 precise (DGM-E04) orbits
- npm 安装错误及处理方法
- Handler源码解析基于ThreadLocal来进行分析
- 1.jquery源码分析-无 new 构造
- BZOJ4868 [Shoi2017]期末考试
- CAN总线基础知识(一)
- 关于TbSchedule任务调度管理框架的整合部署
- makefile中的shell调用---注意事项
- YOLO升级版:YOLOv2和YOLO9000解析
- 玩转https
- 教你如何安装Protocol Buffer
- linux ln -f 只能对文件起作用,不能对文件夹起作用