我原来的写法都是这样:
1
2
3
4
5
6
7
8
9
|
function Dog(){ this .name = 'hachi' ; } Dog.prototype = { makeNoise: function (){ alert( 'wangwangwang' ); } }; |
后来又看到另外一种复杂一点而且看起来好像没有必要的写法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
function Dog(){ var privateVariable = 'secret' ; var fn = function (){ //... } fn.prototype = { makeNoise: function (){ alert( 'wangwangwang' ); } } return fn; } |
这里的Dog函数其实是一个 制造类 的函数,它返回了真正的Dog类。
感觉这样做的好处是更好的实现了封装。
例如这里的privateVariable就是一个私有变量:
1
2
|
var d = new Dog; d.privateVariable //undefined |
另外如果在第一个例子的最后加上一句:
1
2
3
|
Dog.prototype = { //e...WTF?? } |
这样Dog就不是Dog了~
后来的理解:
上面这样新建类的方法直接重写了prototype对象。这样prototype原本内置的属性就没有了(arguments, call, apply等)。
下面这种新建类的方法好像更好一些:
1
2
3
4
5
|
var Dog = function (name){ this .name = name; var privateVariable = 'you cannot see me.' ; this .getPrivate = function (){ return privateVariable;}; } |