JS中的多态实例详解


Posted in Javascript onOctober 15, 2017

 多态在面向对象编程语言中是十分重要的。在JAVA中是通过继承来得到多态的效果。如下:

public abstract class Animal {
abstract void makeSound(); // 抽象方法
}
public class Chicken extends Animal{
public void makeSound(){
System.out.println( "咯咯咯" );
}
}
public class Duck extends Animal{
public void makeSound(){
System.out.println( "嘎嘎嘎" );
}
}
Animal duck = new Duck(); // (1)
Animal chicken = new Chicken(); // (2)

多态的思想实际上是把“做什么”和“谁去做”分离开来,要实现这一点,归根结底先要消除类型之间的耦合关系。
在Java中,可以通过向上转型来实现多态。而javascript的变量在运行期是可变的,一个js对象既可以表示既可以表示Duck类型的对象,又可以表示Chicken类型的对象,这意味着JavaScript对象的多态性是与生俱来的。

多态最根本的作用就是通过把过程化的条件分支语句转化为对象的多态性, 从而消除这些条件分支语句。

假设我们要编写一个地图应用,现在有两家可选的地图API提供商供我们接入自己的应 用。目前我们选择的是谷歌地图,谷歌地图的API中提供了show方法,负责在页面上展 示整个地图。示例代码如下:

var googleMap = {
show: function(){
console.log( '开始渲染谷歌地图' );
}
};
var renderMap = function(){
googleMap.show();
};
renderMap(); // 输出:开始渲染谷歌地图
var googleMap = {
show: function(){
console.log( '开始渲染谷歌地图' );
}
};
var baiduMap = {
show: function(){
console.log( '开始渲染百度地图' );
}
};
var renderMap = function( type ){
if ( type === 'google' ){
googleMap.show();
}else if ( type === 'baidu' ){
baiduMap.show();
}
};
renderMap( 'google' ); // 输出:开始渲染谷歌地图
renderMap( 'baidu' ); // 输出:开始渲染百度地图

可以看到,虽然renderMap函数目前保持了一定的弹性,但这种弹性是很脆弱的,一旦需要替换成搜搜地图,那无疑必须得改动renderMap函数,继续往里面堆砌条件分支语句。

我们还是先把程序中相同的部分抽象出来,那就是显示某个地图:

var renderMap = function( map ){
if ( map.show instanceof Function ){
map.show();
}
};
renderMap( googleMap ); // 输出:开始渲染谷歌地图
renderMap( baiduMap ); // 输出:开始渲染百度地图

之后我们又新增了腾讯地图的支持,那我们很快变可以实现这个功能,而且不必修改原代码:

var TencentMap = {
  show: function(){
console.log( '开始渲染腾讯地图' );
}
}
renderMap( sosoMap ); // 输出:开始渲染腾讯地图

多态技术至关重要,很多设计模式都是巧妙利用多态来实现。

总结

以上所述是小编给大家介绍的JS中的多态实例,希望对大家有所帮助!

Javascript 相关文章推荐
JavaScript 异步调用框架 (Part 1 - 问题 & 场景)
Aug 03 Javascript
扩展IE中一些不兼容的方法如contains、startWith等等
Jan 09 Javascript
实例分析javascript中的call()和apply()方法
Nov 28 Javascript
基于JS实现密码框(password)中显示文字提示功能代码
May 27 Javascript
js+html制作简单验证码
Feb 16 Javascript
Bootstrap modal 多弹窗之叠加显示不出弹窗问题的解决方案
Feb 23 Javascript
Promise.all中对于reject的处理方法
Aug 01 Javascript
Vue基于vuex、axios拦截器实现loading效果及axios的安装配置
Apr 26 Javascript
基于VUE的v-charts的曲线显示功能
Oct 01 Javascript
vue导航栏部分的动态渲染实例
Nov 01 Javascript
js与jquery获取input输入框中的值实例讲解
Feb 27 jQuery
js中火星坐标、百度坐标、WGS84坐标转换实现方法示例
Mar 02 Javascript
vue跨域解决方法
Oct 15 #Javascript
JS实现定时任务每隔N秒请求后台setInterval定时和ajax请求问题
Oct 15 #Javascript
详解 vue.js用法和特性
Oct 15 #Javascript
jQuery实现的页面遮罩层功能示例【测试可用】
Oct 14 #jQuery
JS简单实现数组去重的方法分析
Oct 14 #Javascript
jQuery响应滚动条事件功能示例
Oct 14 #jQuery
JS实现的简单表单验证功能完整实例
Oct 14 #Javascript
You might like
PHP面向对象的使用教程 简单数据库连接
2006/11/25 PHP
PHP中设置时区,记录日志文件的实现代码
2013/01/07 PHP
PHP+Mysql+jQuery中国地图区域数据统计实例讲解
2015/10/10 PHP
laravel 去掉index.php伪静态的操作方法
2019/10/12 PHP
用JavaScript事件串连执行多个处理过程的方法
2007/03/09 Javascript
JQuery select标签操作代码段
2010/05/16 Javascript
基于jquery的textarea发布框限制文字字数输入(添加中文识别)
2012/02/16 Javascript
使用按钮控制以何种方式打开新窗口的属性介绍
2012/12/17 Javascript
js实现n秒倒计时后才可以点击的效果
2015/12/20 Javascript
Active控件问题小结(附解决办法)
2016/06/09 Javascript
基于bootstrap-datetimepicker.js不支持IE8的快速解决方法
2016/11/07 Javascript
jQuery密码强度验证控件使用详解
2017/01/05 Javascript
React Native仿美团下拉菜单的实例代码
2017/08/08 Javascript
解决Vue 浏览器后退无法触发beforeRouteLeave的问题
2017/12/24 Javascript
彻底理解js面向对象之继承
2018/02/04 Javascript
Bootstrap table中toolbar新增条件查询及refresh参数使用方法
2018/05/18 Javascript
vue 实现 rem 布局或vw 布局的方法
2019/11/13 Javascript
浅谈vue-props的default写不写有什么区别
2020/08/09 Javascript
vue实现表格合并功能
2020/12/01 Vue.js
js中实现继承的五种方法
2021/01/25 Javascript
[39:00]Optic vs VP 2018国际邀请赛淘汰赛BO3 第三场 8.24
2018/08/25 DOTA
Python时间戳使用和相互转换详解
2017/12/11 Python
python列表的增删改查实例代码
2018/01/30 Python
python针对excel的操作技巧
2018/03/13 Python
对python中的乘法dot和对应分量相乘multiply详解
2018/11/14 Python
Python使用numpy模块实现矩阵和列表的连接操作方法
2019/06/26 Python
Autopep8的使用(python自动编排工具)
2021/03/02 Python
世界各地的旅游、观光和活动:Isango!
2019/10/29 全球购物
文明家庭先进事迹材
2014/01/27 职场文书
优秀学生干部推荐材料
2014/02/03 职场文书
2014年打非治违工作总结
2014/11/13 职场文书
结婚保证书(卖身契)
2015/02/26 职场文书
催款通知书范文
2015/04/17 职场文书
三八妇女节致辞
2015/07/31 职场文书
2019开业庆典剪彩仪式主持词!
2019/07/22 职场文书
Vue全家桶入门基础教程
2021/05/14 Vue.js