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 相关文章推荐
基于JQuery的日期联动实现代码
Feb 24 Javascript
jquery操作select方法汇总
Feb 05 Javascript
jquery.form.js实现将form提交转为ajax方式提交的方法
Apr 07 Javascript
jQuery插件imgPreviewQs实现上传图片预览
Jan 15 Javascript
微信小程序 仿猫眼实现实例代码
Mar 14 Javascript
easyui-edatagrid.js实现回车键结束编辑功能的实例
Apr 12 Javascript
静态页面实现 include 引入公用代码的示例
Sep 25 Javascript
JavaScript调用模式与this关键字绑定的关系
Apr 21 Javascript
「中高级前端面试」JavaScript手写代码无敌秘籍(推荐)
Apr 08 Javascript
关于element-ui的隐藏组件el-scrollbar的使用
May 29 Javascript
js 解析 JSON 数据简单示例
Apr 21 Javascript
Array.filter中如何正确使用Async
Nov 04 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中创建空文件的代码[file_put_contents vs touch]
2012/01/20 PHP
PHP 观察者模式的实现代码
2013/05/10 PHP
使用PHP+MySql+Ajax+jQuery实现省市区三级联动功能示例
2017/09/15 PHP
详解PHP队列的实现
2019/03/14 PHP
php设计模式之建造器模式分析【星际争霸游戏案例】
2020/01/23 PHP
javascript 树控件 比较好用
2009/06/11 Javascript
用js获取电脑信息(是使用与IE浏览器)
2013/01/15 Javascript
使用node.js 制作网站前台后台
2014/11/13 Javascript
推荐6款基于jQuery实现图片效果插件
2014/12/07 Javascript
jQuery根据用户电脑是mac还是pc加载对应样式的方法
2015/06/26 Javascript
利用jquery制作滚动到指定位置触发动画
2016/03/26 Javascript
动态的9*9乘法表效果的实现代码
2016/05/16 Javascript
通用无限极下拉菜单的实现代码
2016/05/31 Javascript
js中利用cookie实现记住密码功能
2020/08/20 Javascript
JavaScript 实现 Tab 点击切换实例代码
2017/03/25 Javascript
js仿微信抢红包功能
2020/09/25 Javascript
微信小程序左滑删除实现代码实例
2019/09/16 Javascript
javascript实现移动端红包雨页面
2020/06/23 Javascript
[01:22:10]Ti4 循环赛第二日 DK vs Empire
2014/07/11 DOTA
[04:13]2018国际邀请赛典藏宝瓶Ⅱ饰品一览
2018/07/21 DOTA
python 不关闭控制台的实现方法
2011/10/23 Python
详解Python的单元测试
2015/04/28 Python
Python爬取APP下载链接的实现方法
2016/09/30 Python
TensorFlow实现MLP多层感知机模型
2018/03/09 Python
详解python之协程gevent模块
2018/06/14 Python
win10下tensorflow和matplotlib安装教程
2018/09/19 Python
分享PyCharm的几个使用技巧
2019/11/10 Python
基于opencv实现简单画板功能
2020/08/02 Python
详解移动端HTML5音频与视频问题及解决方案
2018/08/22 HTML / CSS
C/C++有关内存的思考题
2015/12/04 面试题
三年级音乐教学反思
2014/01/28 职场文书
公司接待方案
2014/03/08 职场文书
《菜园里》教学反思
2014/04/17 职场文书
高中学校对照检查材料
2014/08/31 职场文书
2014年四风问题自我剖析材料
2014/09/15 职场文书
消防宣传语大全
2015/07/13 职场文书