jQuery.fn = jQuery.prototype = {
// The current version of jQuery being used
jquery: core_version,
constructor: jQuery // ??这里的疑惑
}
上面是jQuery的部分源码,我想知道为什么给jQuery的原型对象上的constructor
重新指向jQuery
?不重新指向的话会出现什么问题?
高洛峰2017-04-10 14:42:06
这里把jQuery.prototype重新赋值了,所以原来的jQuery.prototype.constructor会被覆盖掉。如果jQuery失去constructor的话,就不能通过constructor来构造一个同类型的新对象,也不能用来判断自己的类型。例如下面的代码:
Test = function () {
this.name = "hello";
}
Test.prototype = {};
var t1 = new Test;
var t2 = new t1.constructor;
console.log(t1.constructor === Object); // true
console.log(t2.name); // undefined
参考:http://javascript.info/tutorial/constructor
伊谢尔伦2017-04-10 14:42:06
因为使用jQuery.prototype = {}这样就会是constructor指向Object了,使用要重新更改constructor,改为jQuery.
{}
是对象字面量
,它的constructor是Object
。
所以jquery.prototype={},就会使jquery.prototype的constroctor变为Object。
至于不重新指向有什么结果,只要你在后面的代码中不用到constroctor这个属性的时候,其实是没什么影响的。
比如你要检查构造函数是哪个,那么就有影响。
巴扎黑2017-04-10 14:42:06
jQuery.prototype={}之后,jQuery.prototype会被新赋给他的对象覆盖掉,故原来jQuery.prototype中的constructor就失效了
巴扎黑2017-04-10 14:42:06
jQuery.prototype = {}
这里jQuery.prototype被修改指向了 {}
对象,因此需要重新修正,让他指向jQuery
关于原型基础的详细讲解,推荐阅读《Javascript高级编程》
,精品。
伊谢尔伦2017-04-10 14:42:06
因为默认情况下任何对象(这里是 jQuery
)的原型对象有一个 contructor
的属性,指向这个对象本身,而 jQuery.prototype = {}
相当于重写的 jQuery
的原型对象,所以在这个地方需要重新写上 constructor: jQuery
。