JavaScript的接口原理和使用方法

  介绍

这篇文章主要讲解了JavaScript的接口原理和使用方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。


意义:

提供一种以说明一个对象应该有哪些方法的手段。
接口是面向对象JavaScript程序员的工具箱中最有用的工具之一

接口的利弊:

    <李>

    对于一些中小型程序来说使用接口很显然是不明智的,对项目来说接口的好处也不明显,只是徒增其复杂度而已。

    <李>

    对于接口的好处,那么显而易见首先促进代码的重用,对于开发来讲,还可以告诉程序员那些类都使用了什么方法,如果你事先知道接口那么就减少了你在编码的时候对类与类之间冲突,实现解耦。对于测试和调试也会变得轻松,用于JavaScript的弱类型语言,类型不匹配经常出现,那么使用接口,这一点会变得容易一些。

注释接口描述

优点:程序员可以有一个参考
缺点:属于文档的范畴,这种方式过于松散,没有检查接口的方法是否完全被实现

/*界面复合{
  
  函数添加(obj);
  函数删除(obj);
  功能更新(obj);
  
  }
  
  接口FormItem {
  
  功能选择(obj);
  
  }
  *///CompositeImp1实现复合,FormItem
  var CompositeImpl=function () {//显式在类的内部,接受所实现的接口//一般来说,在类的内部,定义一个数组(数组变量名字固定)
  这一点。implementsInterfaces=[& # 39;复合# 39;& # 39;FormItem& # 39;];//利用implementsInterfaces后续的判断使用
  
  }
  
  CompositeImpl.prototype。删除=函数(obj) {//做某事…
  }
  CompositeImpl.prototype。更新=function (obj) {
  }
  CompositeImpl.prototype。添加=function (obj) {
  警报(& # 39;添加# 39;);
  }
  CompositeImpl.prototype。选择=function (obj) {
  }//检测CompositeImpl类的对象
  函数CheckCompositeImpl(实例){//实例对象作为参数,检测是否存在//判断当前对象是否实现了所有的接口。
  如果(! IsImplements(实例,& # 39;复合# 39;,& # 39;FormItem& # 39;)) {
  把新的错误(& # 39;对象没有实现requried界面# 39;);
  }
  
  }//公用的具体的检测方法(核心方法)//返回布尔值
  函数IsImplements (obj){//判断实例对象,有没有实现相关的接口。//参数对象获得函数的实际参数
  (var i=1;i 

鸭式辩型法

核心:一个类实现接口的主要目的:把接口里的方法都实现。(检测实现方法)
完全面向对象,代码实现统一,也解耦

//1,接口类。//定义一个类,作为借口的基类,通过类实例化N多个接口实例。//类接口
  
  接口类所需要的2个参数
  参数1:接口的名字(字符串)
  参数2:接收方法名称的集合方法,是一个数组(数组)//实现抽象方法
  var=function接口(名称、方法){//方法的名字必须是字符串类型的可以。
  如果参数。长度!=2){
  把新的错误(& # 39;实例界面构造函数参数必须是2的长度! & # 39;);
  };
  this.name=名称;
  this.methods=[];//定义一个内置的空数组对象,等待接受方法里的元素(方法名字);
  (var=0;iJavaScript的接口原理和使用方法