JavaScript中的switch语句

Switch语句

语法:

/*
	switch语法:
		switch(expression){
			case value1:
				statement
				break;
			case value2:
				statement
				break;
			...
			case valueN:
				statement
				break;
			default:
				statement
				break;
		}
*/

switch语句中的每种情形(case)的含义是:“如果表达式等于这个值(value),则执行后面的语句(statement)”。而break关键字会导致代码执行跳出switch语句。如果忽略break关键字,就会导致执行当前的case之后,继续执行下一个case。最后的default关键字则用于在表达式都不匹配前面的任何一种情形时,执行语句(statement)。
举个例子:
用户输入今天是星期几,判断如果是星期六,则活动为去唱歌。如果是星期日,则活动为去植物园;如果是其他,则上班。

var week = prompt("请输入日期:");
switch(week){
	case "星期一":
		alert("上班~");
		break;
	case "星期二":
		alert("上班~");
		break;
	case "星期三":
		alert("上班~");
		break;
	case "星期四":
		alert("上班~");
		break;
	case "星期五":
		alert("上班~");
		break;
	case "星期六":
		alert("去唱歌!");
		break;
	case "星期日":
		alert("去植物园!");
		break;
	default:
		alert("请输入正确的日期!");
}

是不是感觉很麻烦?通过为每个case后面都添加一个break语句,就可能导致书写同样的代码的情况。这时我们可以忽略break关键字,让语句一直执行到最后一条会显示相同代码的地方,在使用break语句跳出。如下所示:

var week = prompt("请输入日期:");
switch(week){
	case "星期一":
	case "星期二":
	case "星期三":
	case "星期四":
	case "星期五":
		alert("上班~");
		break;
	case "星期六":
		alert("去唱歌!");
		break;
	case "星期日":
		alert("去植物园!");
		break;
	default:
		alert("请输入正确的日期!");
}

在阿JavaScript中的switch语句有着与其他语言地方,它有它自己的特色点。首先,可以在switch语句中使用任何数据类型(在很多语言中只能使用数值,比如:Java),无论是字符串还是对象,都没有问题。其次,每个case的值不一定是常量,可以是常量,甚至是表达式。看个例子:

switch("hello world"){
	case 'hello'+'world':
		alert("你好,世界!");
		break;
	case "goodbye":
		alert("byebye");
		break;
	default:
		alert('sorry');
}

在这个例子中,switch语句使用的就是字符串。第一种情况使用的是字符串拼接操作的表达式,因为这个字符串拼接操作的表达式与switch参数相等,,所有结果会下会显示“你好,世界!”。而且,表达式作为case值还可以实现如下操作:

var num = 25;
switch(true){
	case num < 0:
		alert("小于0");
		break;
	case num >= 0 && num <= 20:
		alert("大于0并且小于20");
		break;
	default:
		alert("大于20");
}

因为每个case值都会返回一个boolean值,这样每个case按照顺序求值,直到找到匹配的值或者遇到default语句为止。

注意:switch语句在比较值的时候使用的是全等(===)运算符,因此不会发生类型转换。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值