浅谈jQuery构造函数分析


Posted in Javascript onMay 11, 2015

在我的上一篇文章里面 阐述了jQuery的大致框架,知道了所有代码都是写在了一个自调用匿名函数里面,并且传入了window对象,源码是这样的:

(function( window, undefined ) {...})( window );

我们通过alert(jquery) 知道它是一个对象,那么这个对象是怎么构造出来的呢?我们使用$(document)类似的写法获取元素,就好像直接调用了普通的方法一样,jQuery就是普通的函数吗?如果是构造函数为什么不是 new $(document)的常见形式呢?

其实jQuery是面向对象js库,也有构造函数,每次调用jQuery方法是就会实例化一个jQeury对象,但是jQuery的写法却非常高明。

首先先谈谈js面向对象:  js虽然不是面向对象的语言,却又很多面向对象的写法,这里推荐大家看一下图灵的《javascript高级程序设计》中的面向对象的程序设计部分。在众多方法中比较常使用的写法是构造加原型方式,下面举例:

var Person=function(name,age){
  this.name=name;
  this.age=age;
}
Person.prototype={
 constructor:Person,
 init:function(msg){
  this.say(msg);
 },
 say:function(msg){
 alert(this.name+'说'+msg);
 }
};
var tom=new Person('tom',23); 
tom.init('你好');// tom说你好

其实jQuery也是采用的这种方式只不过用了更聪明的写法,一起再看看jQuery的构造函数有什么不同

// Define a local copy of jQuery
var jQuery = function( selector, context ) {
// The jQuery object is actually just the init constructor 'enhanced'
return new jQuery.fn.init( selector, context, rootjQuery );
},

从源码中可以看到在jQuery真正的函数是init方法,当我们调用jQuery时会返回new init()的结果而不直接new jQuery() .

jQuery.fn是啥呢,在后面我们会看到这样一句代码

jQuery.fn = jQuery.prototype = {...

这样就很好理解了,其实jQuery.fn就是原型对象也就是说在jQuery原型里面有一个init方法,这个方法是真正的构造函数。这样写的好处就是不需要在写$().init()这样的操作,直接就初始化了,但是还有一个问题就是既然init才是构造函数那我们写在jQuery上面的那么方法实例不是不能调用吗?init的实例化自然只能调用init的方法啦,往后看到这样一句代码

// Give the init function the jQuery prototype for later instantiation
jQuery.fn.init.prototype = jQuery.fn;

之前讲过jQuery.fn=jQuery.protype,这就意味着jQuery的原型对象赋给了init的原型,这样jQuery的原型方法自然init也就都有了,通过这样构造方式S使得使用jQuery方法非常简单既不需要new jQuery()的操作也不需要手动初始化就行调用普通函数一样简单。

Javascript 相关文章推荐
js调用flash的效果代码
Apr 26 Javascript
javascript 多种搜索引擎集成的页面实现代码
Jan 02 Javascript
利用js制作html table分页示例(js实现分页)
Apr 25 Javascript
javascript中声明函数的方法及调用函数的返回值
Jul 22 Javascript
IE7浏览器窗口大小改变事件执行多次bug及IE6/IE7/IE8下resize问题
Aug 21 Javascript
两款JS脚本判断手机浏览器类型跳转WAP手机网站
Oct 16 Javascript
详解Bootstrap的aria-label和aria-labelledby应用
Jan 04 Javascript
JS简单设置下拉选择框默认值的方法
Aug 20 Javascript
Ionic + Angular.js实现图片轮播的方法示例
May 21 Javascript
Gulp实现静态网页模块化的方法详解
Jan 09 Javascript
boostrap模态框二次弹出清空原有内容的方法
Aug 10 Javascript
vue中实现弹出层动画效果的示例代码
Sep 25 Javascript
在JavaScript中正确引用bind方法的应用
May 11 #Javascript
jQuery实现页面内锚点平滑跳转特效的方法总结
May 11 #Javascript
javascript实现验证IP地址等相关信息代码
May 10 #Javascript
招聘网站基于jQuery实现自动刷新简历
May 10 #Javascript
javascript实现获取字符串hash值
May 10 #Javascript
Javascript实现计算个人所得税
May 10 #Javascript
AngularJS基础知识笔记之表格
May 10 #Javascript
You might like
PHP+JS无限级可伸缩菜单详解(简单易懂)
2007/01/02 PHP
PHP实现对二维数组某个键排序的方法
2016/09/14 PHP
PHP分享图片的生成方法
2018/04/25 PHP
PHP Redis扩展无法加载的问题解决方法
2019/08/22 PHP
javascript 动态修改样式和层叠样式表代码
2010/04/27 Javascript
date.parse在IE和FF中的区别
2010/07/29 Javascript
javascript算法学习(直接插入排序)
2011/04/12 Javascript
js控制的回到页面顶端goTop的代码实现
2013/03/20 Javascript
button没写type=button会导致点击时提交
2014/03/06 Javascript
兼容所有浏览器的js复制插件Zero使用介绍
2014/03/19 Javascript
js识别不同浏览器基于userAgent做判断
2014/07/29 Javascript
jQuery带箭头提示框tooltips插件集锦
2014/11/17 Javascript
JS点击某个图标或按钮弹出文件选择框的实现代码
2016/09/27 Javascript
基于Vue实现tab栏切换内容不断实时刷新数据功能
2017/04/13 Javascript
解决在Bootstrap模糊框中使用WebUploader的问题
2018/03/22 Javascript
小程序实现展开/收起的效果示例
2018/09/22 Javascript
基于vue框架手写一个notify插件实现通知功能的方法
2019/03/31 Javascript
详解如何修改 node_modules 里的文件
2020/05/22 Javascript
详解Python网络爬虫功能的基本写法
2016/01/28 Python
python中实现k-means聚类算法详解
2017/11/11 Python
python pandas库中DataFrame对行和列的操作实例讲解
2018/06/09 Python
Flask框架Jinjia模板常用语法总结
2018/07/19 Python
Python 获取中文字拼音首个字母的方法
2018/11/28 Python
python通过ffmgep从视频中抽帧的方法
2018/12/05 Python
python 通过视频url获取视频的宽高方式
2019/12/10 Python
python实现PCA降维的示例详解
2020/02/24 Python
TripAdvisor台湾:全球最大旅游网站
2018/08/26 全球购物
大学生创业策划书
2014/02/02 职场文书
上班玩游戏检讨书
2014/02/07 职场文书
高校优秀辅导员事迹材料
2014/05/07 职场文书
授权委托书格式
2014/07/31 职场文书
2015元旦联欢晚会结束语
2014/12/14 职场文书
2015年后备干部工作总结
2015/05/15 职场文书
预防职务犯罪警示教育心得体会
2016/01/15 职场文书
小学六一儿童节活动开幕词
2016/03/04 职场文书
python中出现invalid syntax报错的几种原因分析
2022/02/12 Python