Javascript之面向对象--接口


Posted in Javascript onDecember 02, 2016

接口:对实现某一种任务、功能,目的等,所规定的一些原则。

程序中的接口:规定好有几个方法,方法名是什么。(因程序中要完成任务,都是通过函数或者说方法去实现的。)

javascript中的接口:把实例出来的某"类型对象"、和实例出来的"接口对象",进行一个比较,符合规则,就可以说:这个对象实现了规定的接口;

(接口类:通过这个类,来实例出不同的接口。即不同的接口实例,也就是不同的方法个数和方法名称)

 (进行比较:其实质就是判断子类型实例出来的对象,是否有接口对象中所保存的方法名,还有个数。)

小实例:

电话类,下面可以有“坐机”,“手机”,"平板电脑电话"等等这些子类。而这些子类,都有一个共同的任务、功能或者说是目的---[拔通电话]

为了实现这个功能,不同的子类,可以有不同的内部实现方法,让这个电话能够拔通。但现在为用户考虑的话,必需做出一个规定:

不管你是什么子类型,你实例出来的对象,即有电话功能的对象,要实现[拔通电话],必须有二个方法,

即:1.按出电话号码(数字键)2.按拔号键;

下面是固定的设计模式:

var Interface = function(name,methods){ 
 if(arguments.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,len = methods.length; i <len; i++){ 
  if(typeof methods[i] !== 'string'){ 
   throw new Error("接口方法的名称必须是一个字符串"); 
  } 
  this.methods.push(methods[i]); 
 } 
}; 
//Static class Method 
Interface.ensureImplements = function(myobject1,Iobject1){ 
 if(arguments.length!=2){ 
  throw new Error("方法 Interface.ensureImplemnents 指定了" + arguments.length+ "个参数,但是期望的是2个 ."); 
 } 
 for(var i=1,len = arguments.length; i<len; i++){ 
  var _interface = arguments[i]; 
  //接口对象,要通过接口类实例出来
  if(_interface.constructor !== Interface){ 
   throw new Error("接口,不是通过Interface类,实例出来的"); 
  } 
  //把接口对象里面的方法名取出来,结合到本例中的手机对象,来验证,该手机对象是否有这两个方法,且方法名是不是一样;
  for(var j=0, methodsLen = _interface.methods.length; j<methodsLen;j++ ){ 
   var method = _interface.methods[j]; 
   if(!myobject1[method]||typeof myobject1[method] !== 'function'){ 
    throw new Error("通过验证函数:Interface.ensureImplements: "+myobject1.name+"对象的方法"+ method + " 找不到或者不是一个Function"); 
   } 
  } 
 } 
};

 下面是例子

//通过接口类,实例出一个"拔通电话"的接口;现在这个接口对象testInterface,规定了二个方法,且方法名字是"callfun"和"callnum"
var testInterface = new Interface("call",["callfun","callnum"]);
//移动电话类,的构造函数;
var mobilepone = function(call){ 
 this.name = call;
}
//移动电话类的公有方法
mobilepone.prototype = {
 "constructor":mobilepone,
 //必须和前面接口对象规定的方法名一样;
 "callfun" : function(){
  document.write("按键");
 },
 //必须和前面接口对象规定的方法名一样
 "callnum" : function(){
  document.write("拔号");
 }
}
//通过移动电话类,实例一个三星的手机对象
var anycall = new mobilepone("anycall");
//检测这个个三星的手机对象,是否实现了[拔通电话]这个接口;即把三星手机对象和接口对象做为参数传入验证函数,进行比较
Interface.ensureImplements(anycall,testInterface);
anycall.callnum();

以上就是本文的全部内容,希望对大家有所帮助,感兴趣的可以看下《Javascript之面向对象--方法》和《Javascript之面向对象--封装》谢谢对三水点靠木的支持!

Javascript 相关文章推荐
javascript校验价格合法性实例(必须输入2位小数)
May 05 Javascript
node.js中的buffer.slice方法使用说明
Dec 10 Javascript
JS数组的常见用法实例
Feb 10 Javascript
谷歌showModalDialog()方法不兼容出现对话窗口的解决办法
Feb 15 Javascript
Node.js DES加密的简单实现
Jul 07 Javascript
angular.js中解决跨域问题的三种方式
Jul 12 Javascript
vue2.x+webpack快速搭建前端项目框架详解
Nov 30 Javascript
使用veloticy-ui生成文字动画效果
Feb 08 Javascript
3种vue路由传参的基本模式
Feb 22 Javascript
jquery获取元素到屏幕四周可视距离的方法
Sep 05 jQuery
webpack中如何加载静态文件的方法步骤
May 18 Javascript
Vue 实现监听窗口关闭事件,并在窗口关闭前发送请求
Sep 01 Javascript
Javascript之面向对象--封装
Dec 02 #Javascript
JavaScript制作弹出层效果
Dec 02 #Javascript
Javascript之面向对象--方法
Dec 02 #Javascript
详解基于javascript实现的苹果系统底部菜单
Dec 02 #Javascript
Vue.js组件tree实现省市多级联动
Dec 02 #Javascript
Vue2实现组件props双向绑定
Dec 02 #Javascript
关于Vue.js一些问题和思考学习笔记(2)
Dec 02 #Javascript
You might like
php提交表单发送邮件的方法
2015/03/20 PHP
简单实现PHP留言板功能
2016/12/21 PHP
解决form中action属性后面?传递参数 获取不到的问题
2017/07/21 PHP
Yii1.1框架实现PHP极光推送消息通知功能
2018/09/06 PHP
jquery remove方法应用详解
2012/11/22 Javascript
jquery load事件(callback/data)使用方法及注意事项
2013/02/06 Javascript
阻止事件(取消浏览器对事件的默认行为并阻止其传播)
2013/11/03 Javascript
javascript删除数组元素并且数组长度减小的简单实例
2014/02/14 Javascript
jQuery filter函数使用方法
2014/05/19 Javascript
整理Javascript事件响应学习笔记
2015/12/02 Javascript
谈谈我对JavaScript原型和闭包系列理解(随手笔记6)
2015/12/20 Javascript
jquery属性,遍历,HTML操作方法详解
2016/09/17 Javascript
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
2016/12/15 Javascript
深入浅析angular和vue还有jquery的区别
2018/08/13 jQuery
详解如何在vue项目中使用lodop打印插件
2018/09/27 Javascript
使用python获取CPU和内存信息的思路与实现(linux系统)
2014/01/03 Python
wxpython学习笔记(推荐查看)
2014/06/09 Python
Python打包可执行文件的方法详解
2016/09/19 Python
利用python发送和接收邮件
2016/09/27 Python
利用Python实现Windows下的鼠标键盘模拟的实例代码
2017/07/13 Python
python TCP Socket的粘包和分包的处理详解
2018/02/09 Python
python实现淘宝秒杀脚本
2020/06/23 Python
浅谈python中get pass用法
2019/03/19 Python
浅谈Python中threading join和setDaemon用法及区别说明
2020/05/02 Python
Python 字符串池化的前提
2020/07/03 Python
Anaconda使用IDLE的实现示例
2020/09/23 Python
Auchan Direct波兰:欧尚在线杂货店
2016/10/19 全球购物
C语言面试题
2013/05/19 面试题
求职者简历中的自我评价
2013/10/20 职场文书
党支部组织生活会整改方案
2014/09/30 职场文书
国庆横幅标语
2014/10/08 职场文书
2014年乡镇人大工作总结
2014/11/25 职场文书
2015社区个人工作总结范文
2015/05/13 职场文书
七一慰问简报
2015/07/20 职场文书
古诗文之爱国名句(77句)
2019/09/24 职场文书
Python 中 Shutil 模块详情
2021/11/11 Python