使用隐藏的new来创建对象
JQ中发现的,jQuery.Event类。估计作者是为了减少代码量。定义一个类,但不用new关键字去创建该类对象,而使用方法调用()方式去创建该对象。
很多时候我们是这样写类,然后使用new创建对象的。
1
function Person(name,age){
2
this.name=name;
3
this.age=age;
4
}
5
Person.prototype={
6
setName : function(n){this.name=n;},
7
getName : function(){return this.name;}
8
}
9
var p = new Person('jack',25);
改成这样的
01
function Person(name,age){
02
//条件改为(this==window)或(this==self)或(this.constructor!=Object)
03
if(!this.setName){
04
return new Person(name,age);
05
}
06
this.name=name;
07
this.age=age;
08
}
09
Person.prototype={
10
setName : function(n){this.name=n;},
11
getName : function(){return this.name;}
12
}
13
var p = Person('jack',25);
注意该类较最上面的写类方式中多了以下
1
if(!this.setName){
2
return new Person(name,age);
3
}
好,创建类的实例(对象)方式也变成了如下
1
var p = Person('jack',25);
这种创建方式(函数调用)较上面的少了“new_”,new和空格,实际上是在类内部new了。而这样方式每次创建对象可以减少4个byte。
如果把类内部的if判断条件换成非prototype上的属性,如this.name。程序会提示出错:too much recursion
view sourceprint?
01
function Person(name,age){
02
if(!this.name){
03
return new Person(name,age);
04
}
05
this.name=name;
06
this.age=age;
07
}
08
Person.prototype={
09
setName : function(n){this.name=n;},
10
getName : function(){return this.name;}
11
}
12
var p = Person('jack',25);