3.6 语句

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语句在比较值时,使用的时全等操作符,因此不会发生类型转换。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 4,055评论 0 13
  • 作者的序言 朋友们,弃疗系列4出来啦,作者还并没有放弃,感觉自己萌萌哒,233。 语句 js程序其实就是一系列可执...
    zhaolion阅读 1,700评论 0 8
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,293评论 18 399
  • 十里春风过 万亩梨花开 一日春光暖 半城桃花落
    jscfc阅读 145评论 0 1
  • 亲子夏令营第一天,我和女儿怀着激动的心情第一个走进宽敞明亮的会场,几面五星红旗映入眼帘,不禁肃然起敬。找了...
    杺薇阅读 790评论 4 3