进阶篇:流程控制语句 (4)

2019-05-19  本文已影响0人  饥人谷1904_陈俊锋

饥人谷学习进阶第 4 天

流程控制语句

if:


if (condition) {
    //true statrment
}
else {
    //false statement
}

其中 condition 可以是任意表达式,结果不一定是布尔值,JavaScript解释器会自动调用 Boolean() 将表达式结果转为布尔值,如果表达式为真执行第一个代码块内语句,如果为假执行第二个代码块内语句

可以作为 if 判断条件的类型

  • 1 已定义的变量但未赋值在 if 中认为是假;
  • 2 已定义的变量,赋值为空字符串在 if 中认为是假,赋值为其他的字符串(有字符)就认为是真;
  • 3 已定义的变量,赋值为 true 在 if 中则认为是真,赋值为 false 则认为是假;
  • 4 已定义的变量,赋值为0(还是0.0) 在 if 中则为假,其他数值认为是真;
  • 5 JS 中的特殊值 null,undefined 都是假
  • 6 已定义的函数根据调用方式分为两种:1) 不带括号,如果定义了则为真,没有定义就会报错;2) 带括号的,相当于调用函数,自然是根据函数的返回值判断在真假,没有定义返回值,则返回值默认为undefined;
  • 7 已定义的对象,未赋值在 if 中则为假,赋值后为真(跟第一种情况一样)
    这里本人觉得有点歧义,已定义的对象未赋值应该不属于对象
    由于在JS中变量在没有赋值时是没有类型的,因此和第一种情况是一样的。
  • 8 已定义的对象的属性字段,和单独的变量是一样的;
  • 9 已定义的对象的方法,和单独的函数一样

if 语句的高级写法(可参考)

label:


为代码添加标签,方便后续使用

labelname: statement;

switch:


如果表达式等于case的值,对应的语句就会执行,break关键字会使程序跳出switch语句,很多编程规范强调必须添加break,不添加不会有语法错误,程序会多次判断case,进入相应流程没有一个值符合case,流程进入default子句,很多规范也强调必须添加default部分

JavaScript switch语句虽然参考的C语言的写法,但是有特殊性

switch (expression) {
    case value1:
        statement;
        break;
    case value2:
        statement;
        break;
    case ...
    
    default:
        statement; 
}
switch (true) {
    case 表达式1
        statement;
        break;
    ...
    default:
        statement;
}

while 和 do while:


while (expression) {
    statement;
}
do { 
    statement;
}while (expression)

for:


for语句也是前测试循环语句,但具备在执行循环代码以前初始化变量和定义循环后要执行代码的能力,改造一下while语句

for (var i = 10; i > 0; i--) {
    console.log(i);
}

for-in:


一种迭代语句,用于枚举对象的属性

for (property in object) {
    statement;
}

因为ECMAScript规定对象中的属性没有顺序,所以for-in遍历出来的属性的顺序也不是固定的(虽然大部分浏览器是按属性名称排序,但不能依赖这个)

break 和 continue:


这两个关键字后面可以跟上我们之前提到的label,退出指定位置的代码,对于多层循环是个有用的技巧,但是难以理解,一般不推荐使用(如同C语言中被误解的goto)

with:


with语句同样很少用到,作用是把代码的作用域设置到一个特定对象里,由于其带来性能的严重副作用和可读性的困难,几乎不被使用

with (location) {
    statement;
}
上一篇下一篇

猜你喜欢

热点阅读