JavaScript接口的實現(xiàn)三種方式(推薦)
Javascript模仿接口可以有三種方式:1.注釋法 2.檢查屬性法 3.鴨式辨形法
1.注釋法:此方法屬于程序文檔范疇,對接口的繼承實現(xiàn)完全依靠程序員自覺
/*
interface People{
function createHead();
function createBody();
}
*/
var woman = function(name){ //implements People interface
this.name = name;
}
woman.prototype.showName = function(){
alert(this.name);
}
woman.prototype.createBody = function(){ //實現(xiàn)必要的方法
alert("身體已經(jīng)創(chuàng)建好");
}
woman.prototype.createHead = function(){
alert("頭部已經(jīng)創(chuàng)建好");
}
//2.屬性檢查法:把要實現(xiàn)的接口方法添加到類屬性列表里,通過定義好的檢測反復(fù)檢查是否已經(jīng)實現(xiàn)了那些方法
//優(yōu)缺點:可以強迫程序員實現(xiàn)接口,沒實現(xiàn)就報錯。不過雖然聲明了自己實現(xiàn)了哪些方法,但實現(xiàn)時很可能有遺漏
/*
interface People{
function createHead();
function createBody();
}
*/
var woman = function(name){
this.name = name;
this.implementsInterfaces = ['People'];
}
woman.prototype.showName = function(){
alert(this.name);
}
woman.prototype.createBody = function(){ //實現(xiàn)必要的方法
alert("身體已經(jīng)創(chuàng)建好");
}
woman.prototype.createHead = function(){
alert("頭部已經(jīng)創(chuàng)建好");
}
function implement(obj,interfaces){
for(var i=1;i<interfaces.length;i++){
var interfaceName = interfaces[i];
var interfaceFound = false;
for(var j=0;j<obj.implementsInterfaces.length;j++){
if(obj.implementsInterfaces[j] = interfaceName){
interfaceFound = true;
break;
}
}
if(!interfaceFound){
return false;
}
}
return true;
}
function isImplememts(instance,interfaces){ //判斷對象是否已經(jīng)繼承相應(yīng)接口
if(!implement(instance,interfaces)){
throw new Error("Object doesn't implement a required interface");
}
}
3.鴨式辨型法:(不通過外表判斷鴨子,而通過其是否有鴨子的特性來判斷。如James Whitcomb Riley所說,像鴨子一樣走路并且嘎嘎叫的就是鴨子)
上面?zhèn)z種都聲明了自己實現(xiàn)了那些接口,其實聲明不重要,實現(xiàn)接口核心的是類實現(xiàn)了接口方法集。如果類具有了接口定義的所有方法函數(shù)名相同的函數(shù),那么認為它實現(xiàn)了接口
//接口類,用來創(chuàng)建接口
var Interface = function(name,motheds){
if(agruments.length!=2){
throw new Error("Interface constructor called with "+arguments.length+"arguments,but expected exactly 2");
}
this.name = name;
this.methods = [];
for(var i=0;i<motheds.length;i++){
if(typeof motheds[i] !== 'string'){
throw new Error('Interface constructor expects mothed names to be'+'passes in as a string');
}
this.methods.push(motheds[i]);
}
}
Interface.prototype.ensureImplements = function(objs){
if(agruments.length != 1){
throw new Error("Interface constructor called with "+arguments.length+"arguments,but expected exactly 1")
}
for(var i=0;i<objs.length;i++){
var obj = objs[i];
for(var j=0;j<this.motheds.length;j++){
var mothed = this.methods[j];
if(!obj[mothed] || !typeof obj[mothed] !== 'function'){
throw new Error('Function Interface.ensureImplements:implements interface'+this.name+',obj.mothed'+mothed+'was not found');
}
}
}
}
//創(chuàng)建接口
var People = new Interface('People',['createHead','createBody']);
//子類
var Woman = function(name){
this.name = name;
this.implementsInterfaces = ['People'];
}
Woman.prototype.showName = function(){
alert(this.name);
}
Woman.prototype.createBody = function(){ //實現(xiàn)必要的方法
alert("女人身體已經(jīng)創(chuàng)建好");
}
Woman.prototype.createHead = function(){
alert("女人頭部已經(jīng)創(chuàng)建好");
}
//子類
var Man = function(name){
this.name = name;
this.implementsInterfaces = ['People'];
}
Man.prototype.showName = function(){
alert(this.name);
}
Man.prototype.createBody = function(){ //實現(xiàn)必要的方法
alert("男人身體已經(jīng)創(chuàng)建好");
}
Man.prototype.createHead = function(){
alert("男人頭部已經(jīng)創(chuàng)建好");
}
//判斷是否實現(xiàn)
Poeple.ensureImplements(['Woman','Man']);
- 面向?qū)ο蟮腏avascript之二(接口實現(xiàn)介紹)
- Javascript 面向?qū)ο螅ㄈ┙涌诖a
- JavaScript面向?qū)ο笾薪涌趯崿F(xiàn)方法詳解
- Javascript之面向?qū)ο?-接口
- JavaScript接口實現(xiàn)代碼 (Interfaces In JavaScript)
- Javascript 面向?qū)ο螅ㄒ唬?共有方法,私有方法,特權(quán)方法)
- 淺談Javascript面向?qū)ο缶幊?/a>
- js面向?qū)ο笾R妱?chuàng)建對象的幾種方式(工廠模式、構(gòu)造函數(shù)模式、原型模式)
- javascript面向?qū)ο笕腴T基礎(chǔ)詳細介紹
- 從面試題學(xué)習(xí)Javascript 面向?qū)ο螅▌?chuàng)建對象)
- Javascript 面向?qū)ο螅ǘ┓庋b代碼
- JavaScript 接口原理與用法實例詳解
相關(guān)文章
Intellij中直接運行ts配置方法:run?configuration?for?typescript
run?configuration?for?typescript?插件本質(zhì)還是依賴于ts-node來運行,只是其可以幫助我們自動配置好ts-node運行參數(shù),簡化使用,這篇文章給大家介紹在Intellij中可以借助插件run?configuration?for?typescript直接運行typescript的方法,感興趣的朋友一起看看吧2023-08-08

