js中减少使用不必要的if-else或switch_利用数组/对象代替if-else,switch

时间: 2018-07-16阅读: 4896标签: js知识

无论使用if-else,还是switch。当条件多的时候代码显得非常冗长,而且每次添加条件时需要修改主流程的代码,这样就破坏了类的开闭原则。为解决日后的维护可能存在问题,我们可以采用另一种比较优雅的实现方式来替换if-else,switch吗?


数组替代场景

下面以学生成绩为例,根据不同的分值返回对应的结果,使用if...else代码如下:

function getGrades(num){
	let result='';//返回结果
	if(num < 60) {
		result = "不及格";
	}else if(num < 75) {
		result = "一般";
	} else if(num < 90){
		result = "良好";
	}else{
		result = "优秀";
	}
	return result;
}
console.log(getGrades(60))


使用数组代码如下:

function showGrace(grades,results,curr) {
	for(let i in grades){
		if(curr<grades[i]){
			return results[i]
		}
	}
}
let grades=[60,75,90,101],
results=['不及格','一般','良好','优秀'];
showGrace(grades,results,60)

这样做的好处是:如果有需求修改,只需要修改grades,results的值就可以了,业务逻辑不用修改。


对象替代场景

比如后端返回一个状态值,需要对应它显示的结果,如下:

function getStutes(type){
	switch(type){
		case 0:
			return '不及格'
		case 1:
			return '一般'
		case 2:
			return '良好'
		case 3:
			return '优秀'
	}
}
console.log(getStutes(0))


使用对象如下:

let stutes={
	0:'不及格',
	1:'一般',
	2:'良好',
	3:'优秀',
}
console.log(stutes[0])


如果不直接使用状态值作为key,我们可以如下实现:

function getStutes(type){
	let stutes=[
		{type:0,result:'不及格'},
		{type:1,result:'一般'},
		{type:2,result:'良好'},
		{type:3,result:'优秀'},
	]
	for(let i in stutes){
		if(stutes[i].type==type){
			return stutes[i].result
		}	
	}
}
console.log(getStutes(0))


当然这个例子使用数组会更简单,如下:

let stutes=['不及格','一般','良好','优秀']
console.log(stutes[0])


总结

上面简单的介绍了代替if-else和switch的实现方式。可以看出利用数组,或对象的形式来优化代码,把数据业务逻辑进行了分离,使代码更具有可读性,扩展性,方便于后期的维护。

这种替代方式其实就是js中的一种设计模式——策略模式 ,推荐一篇文章介绍什么是策略模式:javascript 策略模式_理解js中的策略模式


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: http://www.fly63.com/article/detial/932

js的微任务和宏任务

宏任务:当前调用栈中执行的代码成为宏任务。微任务: 当前(此次事件循环中)宏任务执行完,在下一个宏任务开始之前需要执行的任务,可以理解为回调事件。

js浮点数精度丢失问题_如何解决js中浮点数计算不精准?

理解javascript中浮点数计算不精准的原因,如何解决浮点数的四则运算(加减乘除)。js中除了toFixed方法以外的实现方法总汇

js设备判断_判断移动端还是PC端?判断android还是ios?判断移动端浏览器类型?

js判断用户的浏览设备是移动设备还是PC?判断详细浏览器设备信息。判断微信、新浪、QQ打开。判断是android系统还是ios系统...

JavaScript中变量提升和函数提升的意义理解

在ES6之前,Js中是没有块级作用域的,只存在全局作用域和函数作用域。变量提升即将变量声明提升到它所在作用域的最开始的部分;函数提升只有函数声明中才发生。

js检测页面上一个元素是否已经滚动到了屏幕的可视区域内

只要页面加载了,其中在页面中出现的li就向控制台输出第几个发送请求;在本次加载的页面中,再将滚动条滚回前边的li,不再向控制台输出东西,也就是说已经显示过的li,不再向控制台输出东西。

Js常用基础算法

冒泡排序;插入排序 过程就像你拿到一副扑克牌然后对它排序一样;快速排序;回文字符串;翻转字符串;字符串中出现最多次数的字符;数组去重;二分查找

window.location.href的用法(动态输出跳转)

javascript中的location.href有很多种用法,window.location.href 语句可以实现一个框架的页面在执行服务器端代码后刷新另一个框架的页面

JS中for循环的常见题型

for循环示例;让用户输入行数,使用for循环嵌套打出倒着的星星出来,行数等于用户输入的数字 ;有1,2,3,4这么4个数,能组成多少个互不相同且不含有重复数字的三位数?都是多少?

Js实现点击查看全文(类似今日头条、知乎日报效果)

这篇文章主要为大家详细介绍了原生JS+css仿QQ今日头条、知乎日报点击查看全文的效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下.

javascript的Object. hasOwnProperty方法

hasOwnProperty() 方法会返回一个布尔值,指示对象自身属性中(非继承属性)是否具有指定的属性,如果 object 具有带指定名称的属性,则 hasOwnProperty 方法返回 true,否则返回 false。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!