如何用JavaScript定义一个类

  作者:bea

我原来的写法都是这样: function Dog(){ this.name = 'hachi';}Dog.prototype = { makeNoise:function(){ alert('wangwangwang'); }}; 后来又看到另外一种复杂一点而且看起来好像没有必要的写法: function Dog(){ var privateVariable = 'secret'; var fn = function(){ //... }
我原来的写法都是这样:


function Dog(){
this.name = 'hachi';
}

Dog.prototype = {
makeNoise:function(){
alert('wangwangwang');
}
};



后来又看到另外一种复杂一点而且看起来好像没有必要的写法:


function Dog(){
var privateVariable = 'secret';

var fn = function(){
//...
}

fn.prototype = {
makeNoise:function(){
alert('wangwangwang');
}
}

return fn;
}



这里的Dog函数其实是一个 制造类 的函数,它返回了真正的Dog类。 感觉这样做的好处是更好的实现了封装。 例如这里的privateVariable就是一个私有变量:


var d = new Dog;
d.privateVariable //undefined


另外如果在第一个例子的最后加上一句:


Dog.prototype = {
//e...WTF??
}


这样Dog就不是Dog了~
后来的理解: 上面这样新建类的方法直接重写了prototype对象。这样prototype原本内置的属性就没有了(arguments, call, apply等)。 下面这种新建类的方法好像更好一些:


var Dog = function(name){
this.name = name;
var privateVariable = 'you cannot see me.';
this.getPrivate = function(){return privateVariable;};
}





有用  |  无用

猜你喜欢