跳转语句
标签语句
var matrix=getData();//获取二维数组
//将矩阵中所有元素进行求和
var sum=0,success=false;
compute_sum:if(matrix){
for(var x=0;x<matrix.length;x++){
var row = matrix[x];
if(!row)break compute_sum;
for(var y=0;y<row.length;y++){
var cell=row[y];
if(isNaN(cell))break compute_sum;
sum+=cell;
}
}
success=true;
}
//break语句跳转至此
//如果在success在false情况下到达此处说明矩阵计算有问题
不管break语句带不带标签,它的控制权都无法越过函数的边界。比如,对于一条带标签的函数定义语句来说,不能从函数内部通过这个标签来跳转到函数外部。
continue语句
continue语句和break语句非常类似,但它不是退出循环,而是转而执行下一次循环。
需要注意continue语句在while和for循环中的区别, while循环直接进入下一轮的循环条件判断,但for循环首先计算其increment表达式,然后判断循环条件。之前的章节讨论了和while循环“等价”的for循环的行为。但由于continue在这两种循环中的行为表现不同,因此使用while循环不可能完美地模拟等价的for循环。
with语句
with语句用于临时扩展作用域链,它具有如下的语法:
with(object)
statement
这条语句将object添加到作用域链的头部,然后执行statement,最后把作用域链恢复到原始状态。
在严格模式中是禁止使用with语句的,并且在非严格模式里也是不推荐使用with语句的,尽可能避免使用with语句。那些使用with语句的JavaScript代码非常难于优化,并且同没有使用with语句的代码相比,它运行得更慢。
在对象嵌套层次很深的时候通常会使用with语句来简化代码编写。
//访问表单元素
document.forms[0].address.value;
//简化代码
with(document.forms[0]){
name.value ="";
address.value ="";
email.value ="";
}
debugger语句
debugger语句通常什么也不做。然而,当调试程序可用并运行的时候, JavaScript解释器将会(非必需)以调式模式运行。实际上,这条语句用来产生一个断点(breakpoint), JavaScript代码的执行会停止在断点的位置,这时可以使用调试器输出变量的值、检查调用栈等。
function f(o){
if(o===undefined)debugger;
//...
}