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 相关文章推荐
常用的jQuery前端技巧收集
Dec 24 Javascript
js创建对象的方式总结
Jan 10 Javascript
利用Angularjs和原生JS分别实现动态效果的输入框
Sep 01 Javascript
用js实现简单算法的实例代码
Sep 24 Javascript
jQuery插件HighCharts绘制2D柱状图、折线图和饼图的组合图效果示例【附demo源码下载】
Mar 09 Javascript
AngularJS2中一种button切换效果的实现方法(二)
Mar 27 Javascript
Vue 2.0 服务端渲染入门介绍
Mar 29 Javascript
详解Webpack DLL用法以及功能
Jul 11 Javascript
解决Vue 浏览器后退无法触发beforeRouteLeave的问题
Dec 24 Javascript
使用Vue-cli 3.0搭建Vue项目的方法
Jun 07 Javascript
bootstrap 弹出框modal添加垂直方向滚轴效果
Jul 09 Javascript
vue移动端微信授权登录插件封装的实例
Aug 28 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在网页中动态生成PDF文件详细教程
2014/07/05 PHP
服务器上配置PHP运行环境教程
2015/02/12 PHP
深入理解PHP之OpCode原理详解
2016/06/01 PHP
PHP中关于php.ini参数优化详解
2020/02/28 PHP
js静态作用域的功能。
2006/12/25 Javascript
xml 与javascript结合的问题解决方法
2007/03/24 Javascript
JavaScript定义变量和变量优先级问题探讨
2014/10/11 Javascript
jQuery中[attribute]选择器用法实例
2014/12/31 Javascript
JS与Ajax Get和Post在使用上的区别实例详解
2016/06/08 Javascript
基于chosen插件实现人员选择树搜索自动筛选功能
2016/09/24 Javascript
微信小程序 Template详解及简单实例
2017/01/05 Javascript
vuejs父子组件通信的问题
2017/01/11 Javascript
详谈js中数组(array)和对象(object)的区别
2017/02/27 Javascript
js时间戳与日期格式之间相互转换
2017/12/11 Javascript
关于vue-router的那些事儿
2018/05/23 Javascript
vue.js 图片上传并预览及图片更换功能的实现代码
2018/08/27 Javascript
详解关于Angular4 ng-zorro使用过程中遇到的问题
2018/12/05 Javascript
详解如何用webpack4从零开始构建react开发环境
2019/01/27 Javascript
jQuery 实现DOM元素拖拽交换位置的实例代码
2020/07/14 jQuery
vue绑定class的三种方法
2020/12/24 Vue.js
Python利用openpyxl库遍历Sheet的实例
2018/05/03 Python
python 使用正则表达式按照多个空格分割字符的实例
2018/12/20 Python
Python爬虫爬取电影票房数据及图表展示操作示例
2020/03/27 Python
简单聊聊H5的pushState与replaceState的用法
2018/04/03 HTML / CSS
腾讯公司的一个sql题
2013/01/22 面试题
幼儿教师考核制度
2014/01/25 职场文书
授权委托书格式模板
2014/04/03 职场文书
国际经济与贸易专业求职信
2014/07/10 职场文书
分居协议书范本(律师见证版)
2014/11/26 职场文书
2014年技术部工作总结
2014/12/12 职场文书
中秋节寄语2015
2015/03/24 职场文书
2016年优秀团员事迹材料
2016/02/25 职场文书
读《推着妈妈去旅行》有感1500字
2019/10/15 职场文书
再见,2019我们不负使命;你好,2020我们砥砺前行
2020/01/03 职场文书
apache基于端口创建虚拟主机的示例
2021/04/24 Servers
一文简单了解MySQL前缀索引
2022/04/03 MySQL