理解什么是流程控制,知道条件控制的种类并掌握其对应的语法规则,具备利用循环编写简易 ATM 取款机程序能力
运算符
算术运算符
数字是用来计算的,比如:乘法 * 、除法 / 、加法 + 、减法 - 等等,所以经常和算术运算符一起。
算术运算符:也叫数学运算符,主要包括加、减、乘、除、取余(求模)等
运算符 | 作用 |
---|
+ | 求和 |
- | 求差 |
* | 求积 |
/ | 求商 |
% | 取模(取余数),开发中经常用于作为某个数字是否被整除 |
注意:在计算失败时,显示的结果是 NaN (not a number)
赋值运算符
赋值运算符:对变量进行赋值的运算符
= 将等号右边的值赋予给左边, 要求左边必须是一个容器
运算符 | 作用 |
---|
+= | 加法赋值 |
-+ | 减法赋值 |
*= | 乘法赋值 |
/= | 除法赋值 |
%= | 取余赋值 |
根据所需表达式的个数,JS 的运算符可分为一元运算符、二元运算符及三元运算符
自增/自减运算符
符号 | 作用 | 说明 |
---|
++ | 自增 | 变量自身的值加 1,例如: x++ |
— | 自减 | 变量自身的值减 1,例如: x— |
- ++ 在前和 ++ 在后在单独使用时二者并没有差别,而且一般开发中我们都是独立使用
- ++ 在后(后缀式)我们会使用更多
注意:
- 只有变量能够使用自增和自减运算符
- ++、— 可以在变量前面也可以在变量后面,比如: x++ 或者 ++x
比较运算符
使用场景:比较两个数据大小、是否相等,根据比较结果返回一个布尔值(true / false)
运算符 | 作用 |
---|
> | 左边是否大于右边 |
< | 左边是否小于右边 |
>= | 左边是否大于或等于右边 |
⇐ | 左边是否小于或等于右边 |
=== | 左右两边是否 类型 和 值 都相等(重点) |
== | 左右两边 值 是否相等 |
!= | 左右值不相等 |
!== | 左右两边是否不全等 |
逻辑运算符
使用场景:可以把多个布尔值放到一起运算,最终返回一个布尔值
符号 | 名称 | 日常读法 | 特点 | 口诀 |
---|
&& | 逻辑与 | 并且 | 符号两边有一个假的结果为假 | 一假则假 |
|| | 逻辑或 | 或者 | 符号两边有一个真的结果为真 | 一真则真 |
! | 逻辑非 | 取反 | true 变 false false 变 true | 真变假,假变真 |
A | B | A && B | A || B | !A |
---|
false | false | false | false | true |
false | true | false | true | true |
true | false | false | true | false |
true | true | true | true | false |
逻辑运算符里的短路:只存在于 &&
和 ||
中,当满足一定条件则右边代码不会执行
&&
:左边为 false 就短路
||
:左边为 true 就短路
只有 5 个值是 false,其余均为真:false
, 0
, ''
(空), undefined
, none
运算符优先级
逻辑运算符优先级: !> && > ||
语句
表达式和语句
- 表达式是一组代码的集合,JS解释器会将其计算出一个结果
- 语句是JS整句或命令,JS语句是以分号结束(可以省略)
程序三大流程控制语句:顺序结构、分支结构、循环结构
分支语句
分支语句可以根据条件判定真假,来选择性的执行想要的代码
分支语句包含:
- if 分支语句(重点)
- 三元运算符
- switch 语句
if 分支语句
if语句有三种使用:单分支,双分支,多分支
单分支使用语法:
小括号内的条件结果是布尔值,为 true 时,进入大括号里执行代码;为 false,则不执行大括号里面代码
小括号内的结果若不是布尔类型时,会发生类型转换为布尔值,类似 Boolean()
如果大括号只有一个语句,大括号可以省略,但是,俺们不提倡这么做~
if 双分支语句
如果有两个条件的时候,可以使用 if else 双分支语句
例如:
if 多分支语句
使用场景: 适合于有多个条件的时候
三元运算符(三元表达式)
使用场景: 一些简单的双分支,可以使用 三元运算符(三元表达式),写起来比 if else 双分支 更简单
符号:? 与 : 配合使用
语法:
例如:
switch 语句(了解)
使用场景: 适合于有多个条件的时候,也属于分支语句,大部分情况下和 if 多分支语句 功能相同
注意:
- switch case 语句一般用于等值判断, if 适合于区间判断
- switchcase 一般需要配合 break 关键字使用 没有 break 会造成 case 穿透
- if 多分支语句开发要比 switch 更重要,使用也更多
例如:
练习:简单计算器
断点调试
作用: 学习时可以帮助更好的理解代码运行,工作时可以更快找到 bug
浏览器打开调试界面
- 按 F12 打开开发者工具
- 点到源代码一栏 ( sources )
- 选择代码文件
断点: 在某句代码上加的标记就叫断点,当程序执行到这句有标记的代码时会暂停下来。注意打了断点后需要刷新页面,程序才会再次执行。
循环语句
使用场景:重复执行 指定的一段代码,比如我们想要输出 10 次 ’ 我学的很棒 ‘
学习路径:
- while 循环
- for 循环(重点)
while 循环
while : 在…. 期间, 所以 while 循环 就是在满足条件期间,重复执行某些代码。
语法:
例如:
循环三要素:
- 初始值 (经常用变量)
- 终止条件
- 变量的变化量
例如:
中止循环
break
中止整个循环,一般用于结果已经得到,后续的循环不需要的时候可以使用(提高效率)
continue
中止本次循环,一般用于排除或者跳过某一个选项的时候
无限循环
1.while(true)
来构造“无限”循环,需要使用 break 退出循环。(常用)
2.for(;;)
也可以来构造“无限”循环,同样需要使用 break 退出循环。
综合案例 -ATM 存取款机
分析:
① 提示输入框写到循环里面(无限循环)
② 用户输入 4 则退出循环 break
③ 提前准备一个金额预先存储一个数额 money
④ 根据输入不同的值,做不同的操作
(1) 取钱则是减法操作, 存钱则是加法操作,查看余额则是直接显示金额
(2) 可以使用 if else if 多分支 来执行不同的操作
完整代码: