Javascript学习笔记——5.6 跳转

跳转语句(jump statement)可以让程序执行从一个位置跳转到另一个位置。

  • break 跳出当前循环
  • continue 结束本次循环,进入下次循环
  • return 跳出函数体并返回结果
  • throw 抛出异常,与try catch finally一起使用。

标签语句

identifer:statement
定义标签后,可以在程序任何地方通过标签名引用这条语句。
例如:

mainloop:while(token!=null){
//语句1
continue mainloop //跳转到下次循环
//语句2

break

可以退出循环和switch语句,而且只能在这两种语句中出现。
break后面可以跟标签名,当使用break+标签名的方式,break可以跳出任何闭合的语句块(大括号括起来的一组语句)。
在函数中使用break的话,无论带不带标签,都不可能跳出到函数边界以外。

continue

continue和break类似,但它不结束循环,而是跳出本次循环,进入下次循环。它也可以使用标签。

  • 对while和do/while,continue进入下次循环前,先判断循环条件;
  • 对for,continue进入下次循环前,先执行自增表达式,检测test表达式;
  • 对for/in,continue进入下次循环前,先遍历一下个属性名赋值给循环变量。

return

return只能在函数体内出现,遇到return,函数终止执行并返回expression的值给调用程序。
return expression //带返回值
return //不带返回值,返回undefined

throw

用于捕获异常后抛出异常,throw后面可以跟任意类型。
throw expression
Javascript解释器抛出的异常通常是Error类型和其子类型。Error对象有一个name属性表示错误类型,一个message属性存放传递给构造函数的字符串。

当遇到throw时,函数会立即结束执行,并跳入就近的异常处理程序:首先进入当前的catch块,如果没找到对应的catch块,则跳入更上层进行处理,直到遇到相应的catch处理程序,如果一直没有处理程序,则把异常当做错误报告给用户。

try/catch/finally

try/catch/finally是javascript的异常处理机制。
try块内发生异常时,调用catch内的代码逻辑进行处理。
finally是可选的,不管try内是否有异常,都会执行finally内的语句。

try{
//通常来讲,这里的代码会从头执行到尾而不会产生任何问题,
//但有时会抛出一个异常,要么是由throw语句直接抛出异常,
//要么是通过调用一个方法间接抛出异常
}
catch(e){
//当且仅当try语句块抛出了异常,才会执行这里的代码
//这里可以通过局部变量e来获得对Error对象或者抛出的其他值的引用
//这里的代码块可以基于某种原因处理这个异常,也可以忽略这个异常,
//还可以通过throw语句重新抛出异常
}
finally{
//不管try语句块是否抛出了异常,这里的逻辑总是会执行,终止try语句块的方式有:
//1)正常终止,执行完语句块的最后一条语句
//2)通过break、continue或return语句终止
//3)抛出一个异常,异常被catch从句捕获
//4)抛出一个异常,异常未被捕获,继续向上传播
}

你可能感兴趣的:(Javascript学习笔记——5.6 跳转)