全国服务热线:400-6263-721

位置:厦门达内IT教育培训学校 > 学校动态 > 在JavaScript中模仿接口

在JavaScript中模仿接口

来源:厦门达内IT教育培训学校时间:2022/6/13 11:15:50

  在JavaScript中模仿接口主要有三种方式:通过注释、属性检查和鸭式辩型法,以上三种方式有效结合,就会产生类似接口的效果。

  注释是一种比较直观地把与接口相关的关键字(如interface、implement等)与JavaScript代码一同放在注释中来模拟接口,这是较简单的方法,但是效果较差。代码如下:

  //以注释的形式模仿描述接口/*

  interface Composite{

  function add(child);

  function remove(child);

  function getName(index);

  }

  interface FormItem{

  function save();

  }

  */

  //以注释的形式模仿使用接口关键字var CompositeForm =function(id , method,action) { //implements Composite , FormItem

  // do something

  }//模拟实现具体的接口方法 此处实现Composite接口

  CompositeForm.prototype.Add=function(){

  // do something

  }

  CompositeForm.prototype.remove=function(){

  // do something

  }

  CompositeForm.prototype.getName=function(){

  // do something

  }

  //模拟实现具体的接口方法 此处实现FormItem接口

  Composite.prototype.save=function(){

  // do something

  }

  这种方式其实并不是很好,因为这种模仿还只停留在文档规范的范畴,开发人员是否会严格遵守该约定有待考量,对接口的遵守完全依靠开发人员的自觉性。另外,这种方式并不会去检查某个函数是否真正地实现了我们约定的“接口”。尽管如此,这种方式也有优点,它易于实现而不需要额外的类或者函数,可以提高代码的可重用性,因为类实现的接口都有注释说明。这种方式不会影响到文件占用的空间或执行速度,因为注释的代码可以在部署的时候轻松剔除。但是由于不会提供错误消息,它对测试和调试没什么帮助。下面的一种方式会对是否实现接口进行检查,代码如下:

  //以注释的形式模仿使用接口关键字var CompositeForm =function(id , method,action) { //implements Composite , FormItem

  // do something

  this.implementsinterfaces=['Composite','FormItem']; //显式地把接口放在implementsinterfaces中

  }

  //检查接口是否实现function implements(Object){

  for(var i=0 ;i< arguments.length;i++){

  var interfaceName=arguments[i];

  var interfaceFound=false;

  for(var j=0;j

  if(Object.implementsinterfaces[j]==interfaceName){

  interfaceFound=true;

  break;

  }

  }

  if(!interfaceFound){

  return false;

  }else{

  return true;

  }

  }

  }

  function AddForm(formInstance){

  if(!implements(formInstance,'Composite','FormItem')){

  throw new Error('Object does not implements required interface!');

  }

  }

  上述代码是在方式一的基础上进行完善,在这个例子中,CompositeForm宣称自己实现了Composite和FormItem这两个接口,其做法是把这两个接口的名称加入一个implementsinterfaces的数组。显式地声明自己支持什么接口。任何一个要求其参数属性为特定类型的函数都可以对这个属性进行检查,并在所需要的接口未在声明之中时抛出错误。这种方式相对于上一种方式,多了一个强制性的类型检查。但是这种方法的缺点在于它并未增加类真正地实现了自称实现的接口,只是知道它声明自己实现了这些接口。其实类是否声明自己支持哪些接口并不重要,只要它具有这些接口中的方法就行。鸭式辩型(像鸭子一样走路并且嘎嘎叫的就是鸭子)正是基于这样的认识,它把对象实现的方法集作为判断它是不是某个类的实例的标准。这种技术在检查一个类是否实现了某个接口时也可以大显身手。这种方法的背后观点很简单:如果对象具有与接口定义的方法同名的所有方法,那么就可以认为它实现了这个接口。可以使用一个辅助函数来确保对象具有所有必需的方法,代码如下:

  //interfacevar Composite =new Interface('Composite',['add','remove','getName']);var FormItem=new Interface('FormItem',['save']);

  //classvar Composite=function(id,method,action){

  }

  //Common Methodfunction AddForm(formInstance){

  ensureImplements(formInstance,Composite,FormItem);

  //如果该函数没有实现指定的接口,这个函数将会报错

  }

  与另外两种方式不同,这种方式无需注释,其余的各个方面都是可以强制实施的。EnsureImplements函数需要至少两个参数。个参数是想要检查的对象,其余的参数是被检查对象的接口。该函数检查器个参数代表的对象是否实现了那些接口所声明的方法,如果漏掉了任何一个,就会抛错,其中会包含被遗漏的方法的有效信息。这种方式不具备自我描述性,需要一个辅助类和辅助函数来帮助实现接口检查,而且它只关心方法名称,并不检查参数的名称、数目或类型。

领取试听课
每天限量名额,先到先得

尊重原创文章,转载请注明出处与链接:http://www.peixun360.com/1718/news/535909/违者必究! 以上就是厦门达内IT教育培训学校 小编为您整理 在JavaScript中模仿接口的全部内容。

温馨提示:提交留言后老师会第一时间与您联系!热线电话:400-6263-721