欢迎光临
我们一直在努力

通过jQuery源码学习javascript(二)

(function(){ var jquery = function() { // 函数体  } window.jQuery = window.$ = jQuery; })(); console.log(jQuery);

                                     通过jQuery源码学习javascript(二)输出结果

  通过jQuery源码学习javascript(二)

上面的空函数就是所谓的构造函数,构造函数在面向对象语言中是类的一个基本方法。

巧妙2:扩展原型

 

何为原型对象?我给出一篇博文大家可以去了解一下

http://www.cnblogs.com/gnface/archive/2012/08/22/2651534.html

 

javascript为所有函数绑定一个prototype属性,由这个属性指向一个原型对象。我们在原型对象中定义类的继承属性和方法等。

 

原型对象是javascript实现继承的基本机制。

 

(function(){ var jQuery = function() { // 函数体  } jQuery.fn = jQuery.prototype = { // 扩展原型对象 jquery: "1.8.3", test: function() { console.log('test'); } } window.jQuery = window.$ = jQuery; })(); (new jQuery()).test();

 

 

 

巧妙3:使用工厂方法来创建一个实例

 

上面的方法必须使用下面的方法才能进行调用,这样就会产生很多对象,从而浪费内存消耗。

(new jQuery()).test();

jQuery源码使用了很柔和的方法,也是大家比较熟悉的工厂方法,进行调用。

(function(){ var jQuery = function() { // 函数体 return jQuery.fn.init(); } jQuery.fn = jQuery.prototype = { // 扩展原型对象 jquery: "1.8.3", init: function() { return this; }, test: function() { console.log('test'); } } window.jQuery = window.$ = jQuery; })(); jQuery().test();

通过jQuery源码学习javascript(二)

假想1:让jQuery函数体直接返回该对象——我用this

(function(){ var jQuery = function() { return this; } jQuery.fn = jQuery.prototype = { // 扩展原型对象 jquery: "1.8.3", test: function() { console.log('test'); } } window.jQuery = window.$ = jQuery; })(); console.log(jQuery());

                                     通过jQuery源码学习javascript(二)输出结果

通过jQuery源码学习javascript(二)

发现这里的this指向Window对象。

 

假想2:让jQuery函数体直接返回类的实例。

(function(){ var jQuery = function() { return new jQuery(); } jQuery.fn = jQuery.prototype = { // 扩展原型对象 jquery: "1.8.3", test: function() { console.log('test'); } } window.jQuery = window.$ = jQuery; })(); console.log(jQuery());

                                     通过jQuery源码学习javascript(二)输出结果

通过jQuery源码学习javascript(二)

发现上面是一个递归死循环,出现内存外溢。


巧妙4:分隔作用域

 

思考1:init()方法返回的this作用域是什么?

(function(){ var jQuery = function() { // 函数体 return jQuery.fn.init(); } jQuery.fn = jQuery.prototype = { // 扩展原型对象 jquery: "1.8.3", init: function() { this.init_jquery = '2.0'; return this; } } window.jQuery = window.$ = jQuery; })(); console.log(jQuery().jquery); console.log(jQuery().init_jquery);

                                     通过jQuery源码学习javascript(二)输出结果

通过jQuery源码学习javascript(二)

init()方法中的this作用域:this关键字引用了init()函数作用域所在的对象,同时也能够访问上一级对象jQuery.fn对象的作用。——这种思路会破坏作用域的独立性,对于jQuery框架来说,很可能造成消极影响。

思考2:怎么把init()中的this从jQuery.fn对象中分隔出来?——实例化init初始化类型。

(function(){ var jQuery = function() { // 函数体 return new jQuery.fn.init(); } jQuery.fn = jQuery.prototype = { // 扩展原型对象 jquery: "1.8.3", init: function() { this.init_jquery = '2.0'; return this; } } window.jQuery = window.$ = jQuery; })(); console.log(jQuery().jquery); console.log(jQuery().init_jquery);

                                     通过jQuery源码学习javascript(二)输出结果

通过jQuery源码学习javascript(二)

通过实例化init()初始化类型,限定了init()方法里的this,只在init()函数内活动,不让它超出范围。

  • 海报
海报图正在生成中...
赞(0) 打赏
声明:
1、本博客不从事任何主机及服务器租赁业务,不参与任何交易,也绝非中介。博客内容仅记录博主个人感兴趣的服务器测评结果及一些服务器相关的优惠活动,信息均摘自网络或来自服务商主动提供;所以对本博客提及的内容不作直接、间接、法定、约定的保证,博客内容也不具备任何参考价值及引导作用,访问者需自行甄别。
2、访问本博客请务必遵守有关互联网的相关法律、规定与规则;不能利用本博客所提及的内容从事任何违法、违规操作;否则造成的一切后果由访问者自行承担。
3、未成年人及不能独立承担法律责任的个人及群体请勿访问本博客。
4、一旦您访问本博客,即表示您已经知晓并接受了以上声明通告。
文章名称:《通过jQuery源码学习javascript(二)》
文章链接:https://www.456zj.com/20488.html
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址