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 相关文章推荐
10个实用的脚本代码工具
May 04 Javascript
javascript编码的几个方法详细介绍
Jan 06 Javascript
用js获取电脑信息(是使用与IE浏览器)
Jan 15 Javascript
JavaScript中为什么null==0为false而null大于=0为true(个人研究)
Sep 16 Javascript
Jquery 过滤器(first,last,not,even,odd)的使用
Jan 22 Javascript
jQuery无刷新切换主题皮肤实例讲解
Oct 21 Javascript
bootstrap配合Masonry插件实现瀑布式布局
Jan 18 Javascript
node.js的exports、module.exports与ES6的export、export default深入详解
Oct 26 Javascript
使用ngrok+express解决本地环境中微信接口调试问题
Feb 26 Javascript
vue单页缓存存在的问题及解决方案(小结)
Sep 25 Javascript
基于layui实现高级搜索(筛选)功能
Jul 26 Javascript
vue框架中props的typescript用法详解
Feb 17 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 模拟post_验证页面的返回状态(实例讲解)
2013/10/28 PHP
深入了解PHP中的Array数组和foreach
2016/11/06 PHP
php微信公众号开发之微信企业付款给个人
2018/10/04 PHP
yii 框架实现按天,月,年,自定义时间段统计数据的方法分析
2020/04/04 PHP
讲两件事:1.this指针的用法小探. 2.ie的attachEvent和firefox的addEventListener在事件处理上的区别
2007/04/12 Javascript
那些年,我还在学习jquery 学习笔记
2012/03/05 Javascript
jquery DIV撑大让滚动条滚到最底部代码
2013/06/06 Javascript
Javascript事件实例详解
2013/11/06 Javascript
对table和ul实现js分页示例分享
2014/02/24 Javascript
14款NodeJS Web框架推荐
2014/07/11 NodeJs
JQuery设置获取下拉菜单某个选项的值(比较全)
2014/08/05 Javascript
在JavaScript中操作时间之setYear()方法的使用
2015/06/12 Javascript
js调用webservice构造SOAP进行身份验证
2016/04/27 Javascript
Bootstrap CSS组件之面包屑导航(breadcrumb)
2016/12/17 Javascript
jquery实现(textarea)placeholder自动换行
2016/12/22 Javascript
javascript学习之json入门
2016/12/22 Javascript
Vue集成Iframe页面的方法示例
2017/12/12 Javascript
详解使用vue-admin-template的优化历程
2018/05/20 Javascript
详解node字体压缩插件font-spider的用法
2018/09/28 Javascript
JS原生瀑布流效果实现
2019/04/26 Javascript
vue fetch中的.then()的正确使用方法
2020/04/17 Javascript
详解Howler.js Web音频播放终极解决方案
2020/08/23 Javascript
[44:47]Ti4 循环赛第三日 iG vs NaVi
2014/07/12 DOTA
python写的一个文本编辑器
2014/01/23 Python
python实现自动化上线脚本的示例
2019/07/01 Python
Python如何优雅获取本机IP方法
2019/11/10 Python
解析HTML5中的新功能本地存储localStorage
2016/03/01 HTML / CSS
介绍一下Python下range()函数的用法
2013/11/07 面试题
数控专业毕业生求职信范文
2013/09/21 职场文书
争先创优演讲稿
2014/09/15 职场文书
2014年国庆节庆祝建国65周年比赛演讲稿
2014/09/21 职场文书
2014年教学工作总结
2014/11/13 职场文书
2015年党风廉政建设责任书
2015/01/29 职场文书
2015年度企业工作总结
2015/05/21 职场文书
欠条范文
2015/07/03 职场文书
Python编写冷笑话生成器
2022/04/20 Python