return/break语句的妙用

5次阅读

共计 1206 个字符,预计需要花费 4 分钟才能阅读完成。

在 JavaScript 里面,一般我们想让程序在 function 里面执行到一半时,经过判断或者完成某种操作后停止执行后面的代码,会用 return 结束掉 function。
例如:
// 去除前后的空格 function spaceWord(vRet){
if(!vRet) return vRet;
// 条件循环 当不满足自身的条件的时候继续循环, 当达到条件的时候 终止运行 一般用 return
//while 这样的循环语句可以中断代码的执行,
while (true) {// 推出条件
if (vRet.indexOf (‘ ‘) == 0) {
vRet = vRet.substring(1, parseInt(vRet.length));
} else if ((parseInt(vRet.length) != 0) && (vRet.lastIndexOf (‘ ‘) == parseInt(vRet.length) – 1)) {
vRet = vRet.substring(0, parseInt(vRet.length) – 1);
} else {
return vRet;// 使用 return 终止运行 跳出执行体
}
}
}console.log(spaceWord(spaceStr));
但是,如果我要做多层的判断, 而且要中断的只是其中一个判断后面的代码呢?
function(){
// 代码 1 …
if(stopRun == true){
// 代码 2 …
if(cando == false){
return
}
// 代码 3 …
}
// 代码 4 …
}
如果使用 return 终止运行,则代码 3 与代码 4 则不能执行;
对用这种需求妙用 break 来实现代码的中断,而不结束整个函数。
例如:var stopRun = true,cando = false;function ww(){
// 代码 1 …
while(stopRun == true){
// 代码 2 …
console.log(2)
if(cando == false){
break
}
// 代码 3 …
console.log(3)
break
}
// 代码 4 …
console.log(4)
}
上面的逻辑, 当执行到代码 2 语句时,遇到 break 语句,则代码跳出循环执行代码 4 则运行输出为:2 4;则证明代码 3 被阻止了,但是没有阻止函数的运行;
break 不能在 if 里面用,但是可以在循环里面用,所以用 while 这样的循环语句可以中断代码的执行,理论上所有循环都可以实现该功能,选择 while 是因为它简洁而且可以代替 if 做判断。!!! 注意!!!while 最后记得加上一个 break,不然会变成死循环。
可以在 while 中间加入多个 if()break 作为断点,控制逻辑的流程。function(){
var a=0;
while(a==0){
console.log(“ 我要 ”)
a++
if(a!=1)break
console.log(“ 我再要 ”)
a++
if(a!=2)break
console.log(“ 我还要 ”)
break
}
}

正文完
 0