流程控制■ JavaScript条件控制■ JavaScript循环控制

1.流程控制介绍

程序的三种基本结构

顺序结构:从上到下执行的代码就是顺序结构(程序默认就是由上到下顺序执行的)

分支结构:根据不同的情况,执行对应代码

循环结构:重复做一件事情

2.分支结构

(1)、if语句

if 语句 - 只有当指定条件为 true 时,使用该语句来执行代码

if...else 语句 - 当条件为 true 时执行代码,当条件为 false 时执行其他代码

if...else if....else 语句- 使用该语句来选择多个代码块之一来执行

第一种

if (/* 条件表达式 */) {
 // 执行语句
}
第二种
if (/* 条件表达式 */){
 // 成立执行语句
} else {
 // 否则执行语句
}    
第三种
if (/* 条件1 */){
 // 成立执行语句
} else if (/* 条件2 */){
 // 成立执行语句
} else if (/* 条件3 */){
 // 成立执行语句
} else {
 // 最后默认执行语句
}

(2)、三元运算符

表达式1 ? 表达式2 : 表达式3

是对if……else语句的一种简化写法

(3)、switch语句

switch 语句 - 使用该语句来选择多个代码块之一来执行

语法格式:

switch (expression) {
 case 常量1:
   语句;
   break;
 case 常量2:
   语句;
   break;
 case 常量3:
   语句;
   break;
 …
 case 常量n:
   语句;
   break;
 default:
   语句;
   break;
}

break可以省略,如果省略,代码会继续执行下一个case。

default 关键词来规定匹配不存在时做的事情。

switch 语句在比较值时使用的是全等操作符, 因此不会发生类型转换(例如,字符串'10' 不等于数值 10)

(4)、分支结构总结

if语句和switch语句的区别:

if语句:

表达式的结果为boolean类型。常用于区间判断

switch语句:

switch case 使用严格比较(===),值必须与要匹配的类型相同,只有操作数属于同一类型时,严格比较才能为 true。在以下这个例子中,x 将不匹配。

能用switch语句实现的就一定可以使用if实现,但是反之不一定,如果是区间范围就采用if,如果是等值判断使用switch

布尔类型的隐式转换

If语句会把后面的值隐式转换成布尔类型

转换为true :  非空字符串  非0数字  true  任何对象

转换成false : 空字符串  0  false  null  undefined

3.循环结构

在javascript中,循环语句有三种,while、do..while、for循环。

(1)、while语句

while 循环会在指定条件为真时循环执行代码块。

基本语法:

// 当循环条件为true时,执行循环体,
// 当循环条件为false时,结束循环。
while (循环条件) {
 //循环体    
}

(2)、do...while语句

do..while循环和while循环非常像,二者经常可以相互替代,但是do..while的特点是不管条件成不成立,都会执行一次。

基础语法:

do {
 // 循环体;
} while (循环条件);

(3)、for语句

while和do...while一般用来解决无法确认次数的循环。for循环一般在循环次数确定的时候比较方便

for循环语法:

// for循环的表达式之间用的是;号分隔的,千万不要写成,
for (初始化表达式1; 判断表达式2; 自增表达式3) {
 // 循环体4
}

(4)、for循环多个变量的判断原理

 其实就是逗号表达式,总是依据最后一个表达式的值。

(5)、continue和break

break:立即跳出整个循环,即循环结束,开始执行循环后面的内容(直接跳到大括号)

continue:立即跳出当前循环,继续下一次循环(跳到i++的地方)

(6)、循环语句区别

1、循环结构的表达式不同

do-while循环结构表达式为:do{循环体;}。

的结构表达式为:for(单次表达式;条件表达式;末尾循环体){中间循环体;}。

while循环的结构表达式为:while(表达式){循环体}

2、执行时判断方式不同

do-while循环将先运行一次,因为经过第一次do循环后,当检查条件表达式的值时,其值为 不成立时而会退出循环。保证了至少执行do{ }内的语句一次。

执行的中间循环体可以为一个语句,也可以为多个语句,当中间循环体只有一个语句时,其大括号{}可以省略,执行完中间循环体后接着执行末尾循环体。

while循环执行时当满足条件时进入循环,进入循环后,当条件不满足时,执行完循环体内全部语句后再跳出(而不是立即跳出循环)。

3、执行次数不同

do-while循环是先执行后判断,执行次数至少为一次。

for循环是先判断后执行,可以不执行中间循环体。

while循环先判断后执行,可以不执行中间循环体。

4、执行末尾循环体的顺序不同    

do-while循环是在中间循环体中加入末尾循环体,并在执行中间循环体时执行末尾循环体。

for循环的中间循环体在条件判断语句里,执行末尾循环体后自动执行中间循环体。

while循环的末尾循环体也是在中间循环体里,并在中间循环体中执行。

3、调试

(1)、alert()

(2)、console.log()

(3)、debugger 关键字

debugger 关键字用于停止执行 JavaScript,并调用调试函数。这个关键字与在调试工具中设置断点的效果是一样的。如果没有调试可用,debugger 语句将无法工作。开启 debugger ,代码在第三行前停止执行。

(4)、断点调试

断点调试是指自己在程序的某一行设置一个断点,调试时,程序运行到这一行就会停住,然后你可以一步一步往下调试,调试过程中可以看各个变量当前的值,出错的话,调试到出错的代码行即显示错误,停下。

调试步骤:

浏览器中按F12-->sources-->找到需要调试的文件-->在程序的某一行设置断点

调试中的相关操作:

Watch: 监视,通过watch可以监视变量的值的变化,非常的常用。
    F10: 程序单步执行,让程序一行一行的执行,这个时候,观察watch中变量的值的变化。
    F8:跳到下一个断点处,如果后面没有断点了,则程序执行结束。

注意: 监视变量,不要监视表达式,因为监视了表达式,那么这个表达式也会执行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值