ECMA-262规定了一组语句(也称为流控制语句)。从本质上看,语句定义了ECMAScript中的主要语法,语句通常使用一或多个关键字来完成给定的任务。语句可以很简单,例如通知函数推出;也可以比较复杂,例如指定重复执行某个命令的次数。
3.6.1 if语句
大多数编程语言中,最常用的一个语句就是if语句,以下是if语句的语法:
if (condition) statement1 else statement2
其中的condition(条件)可以是任意表达式;而且对这个表达式求值的结果不一定是布尔值。ECMAScript会自动调用Boolean()转换函数将这个表达式的结果转换成一个布尔值。
推荐使用代码块,即用{}包起来。
3.6.2 do-while语句
do-while语句是一种后测试循环语句,即只有在循环体中的代码执行之后,才会测试出口条件。换句话说,在对条件表达式求值之前,循环体内的代码至少会被执行以此。以下是do-while语句的语法:
do {
statement
} while (expression)
示例:
var i = 0;
do {
i += 2;
} while (i < 10);
console.log(i);
想do-while这种后测试循环语句最常用于循环体中的代码至少要被执行以此的情形
3.6.3 while语句
while语句属于前测试循环语句,也就是说,在循环体内的代码被执行前,就会对出口条件求值。因此,循环体内的代码可能永远都不会被执行。以下是while语句的语法:
while (expression) statement
下面是一个示例:
var i = 0;
while (i < 10) {
i += 2;
}
console.log(i);
3.6.4 for语句
for语句也是一种前测试循环语句,但是它具有在执行循环前初始化变量和定义循环后要执行的代码的能力。以下是for语句的语法:
for (initialization; expression; post-loop-expression) statement
下面是一个示例:
var count = 10;
for (var i = 0; i < count; i++) {
console.log(i);
}
以上代码定义了变量i的初始值为0。只有当条件表达式(i<count)返回true的情况下才会进入for循环,因此也有可能不会执行循环体中的代码。如果执行了循环体中的代码,则一定会对循环后的表达式(i++)求值。这个for循环语句与下面的while语句的功能相同:
var count = 10;
var i = 0;
while (i < count) {
console.log(i);
i++;
}
使用while循环做不到的,使用for循环同样也做不到。也就是说,for循环值是把与循环有关的代码集中在了一个位置。
此外,for语句中的初始化表达式、控制表达式和循环后表达式都是可选的。将这三个表达式全部省略,就会创建一个无限循环,例如:
for (;;) {
doSomeThing();
}
3.6.5 for-in语句
for-in语句是一种精准的迭代语句,可以用来枚举对象的属性。以下是for-in语句的语法:
for (property in expression) statement
下面是一个示例:
for (var propName in window) {
document.write(propName);
}
这个例子中,我们使用for-in循环来显示了BOM中window对象的所有属性。每次执行循环时,都会将window对象中存在的一个属性名赋值给变量propName。这个过程会以制持续到对象中的所有属性都被枚举一遍为止。
ECMAScript对象的属性没有顺序。因此,通过for-in循环输出的属性名的顺序时不可预测的。具体来将,所有属性都会被返回一次,但返回的先后顺序可能会因浏览器而异。
但是,如果表达式要迭代的对象的变量值为null或undefined,for-in语句会抛出错误。ECMAScript5更正了这一行为;对这种情况不再抛出错误,而只是不执行循环体。为了保证最大限度的兼容性,建议在使用for-in循环之前,先检测确认该对象是否为null或undefined。
safari 3以前版本的for-in语句中存在一个bug,该bug会导致某些属性被返回两次。
3.6.6 label语句·
使用label语句可以在代码中添加标签,以便将来使用。以下是lable语句的语法:
label: statement
下面是一个示例:
start: for (var i = 0; i < 10; i++) {
console.log(i);
}
这个例子中定义的start标签可以在将来由break或continue语句引用。加标签的语句一般都要与for语句等循环语句配合使用。
3.6.7 break和continue语句
break和continue语句用于在循环中精确地控制代码的执行。其中,break语句会立即退出循环,强制继续执行循环后面的语句。而continue语句虽然也是立即退出循环,但退出循环后会从循环的顶部继续执行。请看下面的例子:
var num = 0;
for (var i = 1; i < 10; i++) {
if (i % 5 == 0) {
break;
}
num++;
}
console.log(num);
var num = 0;
for (var i = 1; i < 10; i++) {
if (i % 5 == 0) {
continue;
}
num++;
}
console.log(num);//8
下面是结合label语句的使用例子:
var num = 0;
outermost:
for (var i = 0; i < 10; i++) {
for (var j = 0; j < 10; j++) {
if (i == 5 && j == 5) {
break outermost;
}
num++;
}
}
console.log(num);//55
var num = 0;
outermost:
for (var i = 0; i < 10; i++) {
for (var j = 0; j < 10; j++) {
if (i == 5 && j == 5) {
continue outermost;
}
num++;
}
}
console.log(num);//95
但是,这里的label语句到底起了什么作用呢?其实就说说明作用。所以不常用。
3.6.8 with语句
with语句的作用是将代码的作用于设置到一个固定的对象中。with语句的语法如下:
with (expression) statement;
定义with语句的目的主要是简化多次编写同一个对象的工作,如下面的例子:
with(location){
var qs = search.substring(1);
var url = href;
}
console.log(qs);
console.log(url);
在这个例子中,使用with语句关联了location对象。这意味着在with语句的代码块内部,每个变量首先先被认为是一个局部变量,而如果在局部环境中找不到该变量的定义,就会查询location对象中是否有同名的属性。如果发现了同名的属性,则以location对象属性的值组哦为变量的值。
严格模式下不允许使用with语句,否则将视为语法错误。
由于大量使用with语句会导致性能下降,同时也会给调试代码造成困难,因此在开发大型应用程序时,不建议使用with语句。
3.6.9 switch语句
switch语句与if语句的关系最为密切,而且也是在其他语言中普遍使用的一种流控制语句。ECMAScript中switch语句的语法与其他基于C的语言非常接近,如下所例:
switch (expression) {
case value: statement
break;
case value: statement
break;
case value: statement
break;
default: statement;
}
假如需要混合集中情形,不要忘了在代码中添加注释,说明你是有意省略break关键字,如下所示:
switch (i) {
case 25:
/*合并两种情况*/
case 35:
break;
case 45:
break;
default:
console.log("other");
}
虽然ECMAScript中的switch语句借鉴自其他语言,但这个语句也有自己的特色。首先,可以在switch语句中使用任何数据类型(在很多其他语言中只能使用数值),无论是字符串,还是对象都么有问题。其次,每个case的值不一定是常量,也可以是变量,甚至是表达式。例子:
switch ("hello world") {
case "hello" + "world":
console.log("Greeting was found.");
break;
case "goodbye":
console.log("Closing was found.")
break;
default:
console.log("Unexpected message was found.");
break;
}
使用表达式组哦为case值还可以实现下列操作:
var num = 25;
switch (true) {
case num < 0:
console.log("Less than 0.");
break;
case num >= 0 && num <= 10:
console.log("Between 0 and 10.");
break;
case num > 10 && num <= 20:
console.log("Between 11 and 20.");
break;
default:
console.log("More than 20.");
}
switch语句在比较值时,使用的时全等操作符,因此不会发生类型转换。
网友评论