点评:Class属性Extends和Implements有什么区别,想必很多新手朋友们都不知道吧,下面通过实例为大家详细的介绍下,感兴趣的朋友可不要错过
AuBHTML5中文学习网 - HTML5先行者学习网
<span style="font-size:12px;">var Animal = new Class({ AuBHTML5中文学习网 - HTML5先行者学习网
initialize: function(age){ AuBHTML5中文学习网 - HTML5先行者学习网
this.age = age; AuBHTML5中文学习网 - HTML5先行者学习网
} AuBHTML5中文学习网 - HTML5先行者学习网
}); AuBHTML5中文学习网 - HTML5先行者学习网
var Cat = new Class({ AuBHTML5中文学习网 - HTML5先行者学习网
Extends: Animal, AuBHTML5中文学习网 - HTML5先行者学习网
initialize: function(name, age){ AuBHTML5中文学习网 - HTML5先行者学习网
this.parent(age); // calls initalize method of Animal class AuBHTML5中文学习网 - HTML5先行者学习网
this.name = name; AuBHTML5中文学习网 - HTML5先行者学习网
} AuBHTML5中文学习网 - HTML5先行者学习网
}); AuBHTML5中文学习网 - HTML5先行者学习网
var myCat = new Cat('Micia', 20); AuBHTML5中文学习网 - HTML5先行者学习网
console.log(myCat.name); //'Micia'. AuBHTML5中文学习网 - HTML5先行者学习网
console.log(myCat.age); // 20.</span> AuBHTML5中文学习网 - HTML5先行者学习网
AuBHTML5中文学习网 - HTML5先行者学习网 AuBHTML5中文学习网 - HTML5先行者学习网
<span style="font-size:12px;">var Dog = new Class({ AuBHTML5中文学习网 - HTML5先行者学习网
Implements: Animal, AuBHTML5中文学习网 - HTML5先行者学习网
setName: function(name){ AuBHTML5中文学习网 - HTML5先行者学习网
this.name = name AuBHTML5中文学习网 - HTML5先行者学习网
} AuBHTML5中文学习网 - HTML5先行者学习网
}); AuBHTML5中文学习网 - HTML5先行者学习网
var myAnimal = new Dog(20); AuBHTML5中文学习网 - HTML5先行者学习网
console.log(myAnimal.age); AuBHTML5中文学习网 - HTML5先行者学习网
myAnimal.setName('Micia'); AuBHTML5中文学习网 - HTML5先行者学习网
console.log(myAnimal.name); // 'Micia'. AuBHTML5中文学习网 - HTML5先行者学习网
</span> AuBHTML5中文学习网 - HTML5先行者学习网
AuBHTML5中文学习网 - HTML5先行者学习网通过Extends实现继承时,需要通过调用parent方法来调用父元素的initialize方法从而继承父元素的属性
AuBHTML5中文学习网 - HTML5先行者学习网AuBHTML5中文学习网 - HTML5先行者学习网而通过Implements实现继承时,直接就可以继承父元素的属性,这种方式很适合父类不止一个的情况下
AuBHTML5中文学习网 - HTML5先行者学习网AuBHTML5中文学习网 - HTML5先行者学习网另外额外补充类方法Implement和extend,这两个方法用于扩展已经定义了的类
AuBHTML5中文学习网 - HTML5先行者学习网 AuBHTML5中文学习网 - HTML5先行者学习网
<span class="kw2"><span style="font-size:12px"></span></span><pre name="code" class="javascript"><span style="font-size:12px;">var Animal = new Class({ AuBHTML5中文学习网 - HTML5先行者学习网
initialize: function(age){ AuBHTML5中文学习网 - HTML5先行者学习网
this.age = age; AuBHTML5中文学习网 - HTML5先行者学习网
} AuBHTML5中文学习网 - HTML5先行者学习网
}); AuBHTML5中文学习网 - HTML5先行者学习网
Animal.implement({ AuBHTML5中文学习网 - HTML5先行者学习网
setName: function(name){ AuBHTML5中文学习网 - HTML5先行者学习网
this.name = name; AuBHTML5中文学习网 - HTML5先行者学习网
} AuBHTML5中文学习网 - HTML5先行者学习网
}); AuBHTML5中文学习网 - HTML5先行者学习网
var myAnimal = new Animal(20); AuBHTML5中文学习网 - HTML5先行者学习网
myAnimal.setName('Micia'); AuBHTML5中文学习网 - HTML5先行者学习网
console.log(myAnimal.name); //'Micia'</span></pre><span style="font-size:12px">AuBHTML5中文学习网 - HTML5先行者学习网
<span class="co1"></span></span> AuBHTML5中文学习网 - HTML5先行者学习网
AuBHTML5中文学习网 - HTML5先行者学习网“The main difference between extend and implement is that Implement changes the class's prototype, while Extend creates a copy. This means that if you implement a change into a class all instances of that class will inherit that change instantly, while if you use Extend then all existing instances will remain the same。”
AuBHTML5中文学习网 - HTML5先行者学习网AuBHTML5中文学习网 - HTML5先行者学习网简单翻译下:extend和implement的主要区别是,implement改变了类的prototype属性,而extend只是新建了一个副本。这意味着如果你通过implement对类做了改变,那将改变他的所有实例,而通过extend改变类的话,不会改变在此之前存在的实例。
AuBHTML5中文学习网 - HTML5先行者学习网 AuBHTML5中文学习网 - HTML5先行者学习网
var Thingy = new Class({ AuBHTML5中文学习网 - HTML5先行者学习网
go: function(){ AuBHTML5中文学习网 - HTML5先行者学习网
alert('hi'); AuBHTML5中文学习网 - HTML5先行者学习网
} AuBHTML5中文学习网 - HTML5先行者学习网
}); AuBHTML5中文学习网 - HTML5先行者学习网
var myClass = new Thingy(); AuBHTML5中文学习网 - HTML5先行者学习网
myClass.go(); /* alerts 'hi' */ AuBHTML5中文学习网 - HTML5先行者学习网
Thingy.implement({ AuBHTML5中文学习网 - HTML5先行者学习网
go: function(){ AuBHTML5中文学习网 - HTML5先行者学习网
alert('implemented'); AuBHTML5中文学习网 - HTML5先行者学习网
} AuBHTML5中文学习网 - HTML5先行者学习网
}); AuBHTML5中文学习网 - HTML5先行者学习网
myClass.go(); /* alerts 'implemented' */ AuBHTML5中文学习网 - HTML5先行者学习网
Thingy = Thingy.extend({ AuBHTML5中文学习网 - HTML5先行者学习网
go: function(){ AuBHTML5中文学习网 - HTML5先行者学习网
alert('extended'); AuBHTML5中文学习网 - HTML5先行者学习网
} AuBHTML5中文学习网 - HTML5先行者学习网
}); AuBHTML5中文学习网 - HTML5先行者学习网
myClass.go(); /* alerts 'implemented' AuBHTML5中文学习网 - HTML5先行者学习网
because extend only affects AuBHTML5中文学习网 - HTML5先行者学习网
new instances. */ AuBHTML5中文学习网 - HTML5先行者学习网