多态在面向对象程序设计中的作用 js代码

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

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 googleMap = {
	show:function(){
		console.log("开始渲染谷歌地图");
	}
}

var baiduMap = {
	show:function(){
		console.log("开始渲染百度地图");
	}
}

var gaodeMap = {
	show:function(){
		console.log("开始渲染高德地图");
	}
}

var renderMap = function( map ){
	if(map.show instanceof Function){
		map.show();
	}
};
renderMap( googleMap );
renderMap( baiduMap );
renderMap( gaodeMap );
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

春风得意之时

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值