JavaScript基础02

运算符

算数运算符

数学运算符也叫算数运算符,包括加(+)、减(-)、乘(*)、除(/)、取余(%)(求模)。

()可以提升优先级,其优先级与数学中计算的优先级相同,先乘除后加减,括号优先算

<!DOCTYPE html>
<html lang="en">
<head>
</head>

<body>
    <script>
        console.log(4 / 2)//输出2
        console.log(4 % 2)//输出0
        console.log(2 % 4)//输出2
        console.log(5 % 8)//输出5
    </script>
</body>

</html>

赋值运算符

=将等号右边的值赋予给等号左边,要求左边必须是一个容器

+=将该符号右边的值与左边的值相加后赋予左边的值

-=将该符号右边的值与左边的值相见后赋予左边的值

/=将该符号左边的值除以右边的值后赋予左边的值

%=将该符号左边的值对右边的值取余后后赋予左边的值

<!DOCTYPE html>
<html lang="en">

<head>
</head>

<body>
    <script>
        // 两个变量的 把i加到 sum 里面去
        let i = 1
        let sum = 0
        // sum = sum + i
        sum += i
        let num1 = 10
        num1 /= 2
        console.log(num1); //输出5
    </script>
</body>

</html>

一元运算符

一元运算符能够使变量做自增或自减运算或取反!

定义一个变量num,num++,++num为自增,num–,--num为自减

前置自增:++num先自增再使用

后置自增:num++先使用再自增

一般开发中使用后置自增较多

<!DOCTYPE html>
<html lang="en">

<head>
</head>

<body>
    <script>
        // 前置自增
        // let i = 1
        // 先自加 再使用
        // console.log(++i + 2)  // 4
        // 后置自增
        let i = 1
        // 先使用 后自加
        console.log(i++ + 2) // 输出为3
        console.log(i)//输出为2,已经做自增了
    </script>
</body>

</html>

比较运算符

> : 左边是否大于右边

<: 左边是否小于右边

>= 左边是否大于或等于右边

<=: 左边是否小于或等于右边

==: 左右两边是否相等

===: 左右两边是否类型和值都相等

!==: 左右两边是否不全等

比较结果为boolean类型,即只会得到true或false

比较运算符实际上是比较字符对应ASCII码

NAN不等于任何值,包括它本身

尽量不要比较小数,因为小数有精度问题

不同类型之间比较会发生隐式转换成number类型再比较

所以在开发中,如果进行准确比较我们更喜欢===或者!==

<!DOCTYPE html>
<html lang="en">

<head>
</head>

<body>
    <script>
        console.log(3 > 5) // 输出false
        console.log(5 >= 5) // 输出 true
        // console.log(5 = 5)
        console.log(5 == 5)//输出true
        // == 只要值一样就是true  不管数据类型
        console.log(5 == '5')//输出true
        console.log(5 == 'pink')//输出false
        // === 以后判断要用  ===  开发常用   要求值和数据类型都一样
        console.log(5 === 5)//输出true
        console.log(5 === '5')//输出false
        // 特殊情况
        console.log('pink' > 'red')//输出true
        console.log('pink' > 'pin')//输出false
        console.log(1 === NaN)//输出false
        console.log(NaN === NaN)//输出false
        console.log(0.1 + 0.2 === 0.3)//输出false
        console.log(0.1 + 0.2)//输出0.30000000004

        console.log(3 > '2')
    </script>
</body>

</html>

逻辑运算符

逻辑运算符使用

javascript三则运算 javascript中的运算符_javascript

逻辑运算符里的短路

javascript三则运算 javascript中的运算符_前端_02

运算符优先级

javascript三则运算 javascript中的运算符_开发语言_03

javascript三则运算 javascript中的运算符_html_04

语句

表达式和语句

表达式是一组代码的集合,js解释器会将其计算为一个结果,

语句是js整句或命令,比如if语句,for循环语句

表达式 :3 + 4

语句 :

alert() 弹出对话框 ,if语句,for语句,switch语句

其实某些情况,也可以把表达式理解为语句,因为它是在计算结果,也是做事

分支语句

以前我们写的代码,写几句就从上往下执行几句,这种叫顺序结构

有的时候要根据条件选择执行代码,这种就叫分支结构

某段代码被重复执行,就叫循环结构

javascript三则运算 javascript中的运算符_javascript三则运算_05

if分支语句

if语句有三种使用:单分支、双分支、多分支

单分支

javascript三则运算 javascript中的运算符_开发语言_06

<!DOCTYPE html>
<html lang="en">

<head>
</head>

<body>
  <script>
    //弹出框,搜集用户信息,转换为数字类型
    let score = prompt('输入您的高考成绩') * 1
    //如果分数大于等于700,则弹框...
    if (score >= 700) {
      alert('恭喜您考入清华大学')
    }
  </script>
</body>

</html>
双分支

javascript三则运算 javascript中的运算符_前端_07

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <script>
    //弹出框,搜集用户信息,转换为数字类型
    let score = prompt('输入您的高考成绩') * 1
    //如果分数大于等于700,则弹框...
    if (score >= 700) {
      alert('恭喜您考入清华大学')
    }
    否则弹框...
    else {
       alert('很可惜,您落榜了.')
    }
  </script>
</body>

</html>
多分支

javascript三则运算 javascript中的运算符_javascript_08

<!DOCTYPE html>
<html lang="en">

<head>
</head>

<body>
    <script>
        // 1. 用户输入时间 结合api 可自动获取时间
        let time = prompt('请输入小时:')
        // 2. 多分支判断
        if (time < 12) {
            document.write(`上午好,好好工作`)
        } else if (time < 18) {
            document.write(`下午好,好好工作`)
        } else if (time < 20) {
            document.write(`晚上好,好好加班`)
        } else {
            document.write(`夜深了,头发还有吗?`)

        }
        // 12 - 18   下午
        // 我们输入的时间 要大于12 并且小于 18 算下午
        // time >12 && time < 18
    </script>
</body>

</html>

三元运算符

语法:

javascript三则运算 javascript中的运算符_javascript_09

一般用来取值,可以将双分支语句代码简化

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script>
        // console.log(true ? 1 : 2)
        // console.log(false ? 1 : 2)

        // if (3 > 5) {
        //     alert('第一个')

        // } else {
        //      alert('第二个')
        // }
			 //以上语句可简化为以下一居
        // 3 > 5 ? alert('第一个') : alert('第二个')
        let num1 = 40
        let num2 = 30
        // num1 > num2 ? console.log(num1) : console.log(num2)
			 //需求:用户输入1个数,如果数字小于10,则前面进行补0, 比如 09 03 等
        // let re = num1 > num2 ? num1 : num2
        let re = num1 > num2 ? num1 : num2
        console.log(String('0' + num1))

        console.log(re)
        // let re = 3 + 5
    </script>
</body>

</html>

swich语句

语法

javascript三则运算 javascript中的运算符_前端_10

javascript三则运算 javascript中的运算符_前端_11

  1. switch case语句一般用于等值判断,不适合于区间判断
  2. switch case一般需要配合break关键字使用 没有break会造成case穿透,当运行至break会使循环直接结束.
<!DOCTYPE html>
<html lang="en">

<head>
</head>

<body>
    <script>
        // 1. 用户输入数字   还有一次 运算符
        let num1 = +prompt('请您输入第一个数:')
        let num2 = +prompt('请您输入第二个数:')
        let sp = prompt('请您输入+ - * / 运算')
        // 2. 根据不同的运算符计算不同的结果 switch
        switch (sp) {
            case '+':
                alert(`您选择的是加法,结果是: ${num1 + num2}`)
                break
            case '-':
                alert(`您选择的是减法,结果是: ${num1 - num2}`)
                break
            case '*':
                alert(`您选择的是乘法,结果是: ${num1 * num2}`)
                break
            case '/':
                alert(`您选择的是除法,结果是: ${num1 / num2}`)
                break
            default:
                alert(`你输了啥? 请输入+ - * / `)
        }
    </script>
</body>

</html>

循环语句

浏览器调试方法

javascript三则运算 javascript中的运算符_开发语言_12

while循环

while循环语法

javascript三则运算 javascript中的运算符_前端_13

跟if语句很像,都要满足小括号里的条件为true才会进入执行代码

while大括号里代码执行完毕后不会跳出,而是继续回到小括号里判断条件是否满足,若满足又执行大括号里的代码,然后再回到 小括号判断条件,直到括号内条件不满足,即跳出

循环需要具备三要素:

  1. 变量起始值
  2. 终止条件(没有终止条件,循环会一直执行,造成死循环)
  3. 变量变化量(用自增或者自减)
<!DOCTYPE html>
<html lang="en">

<head>
</head>

<body>
    <script>
        // 循环必须有3要素
        // 变量的起始值
        let i = 1
        // 终止条件
        while (i <= 3) {
            document.write(`月薪过万 <br>`)
            // 变量变化
            i++
        }
    </script>
</body>

</html>
<!DOCTYPE html>
<html lang="en">

<head>
</head>

<body>
    <script>
        // 1. 输出 1~100个数字
        // 起始值
        // let i = 1
        // // 终止条件
        // while (i <= 100) {
        //     document.write(` <p>是:${i} </p>`)
        //     // 变量变化
        //     i++
        // }

        // 2. 计算1~100 的累加和  1+2+3+.. + 100
        // let j = 1
        // let sum = 0
        // while (j <= 100) {
        //     // sum = sum + j
        //     sum += j
        //     j++
        // }
        // console.log(sum)  // 5050

        // 3. 求 1~100 之间的偶数累加和
        let i = 1
        let sum = 0
        while (i <= 100) {
            if (i % 2 === 0) {
                // 此时 i 一定是偶数
                sum = sum + i
            }
            // 不管你是偶数还是奇数我都要++
            i++
        }
        console.log(sum)
    </script>
</body>

</html>
循环退出

循环结束:

continue:结束本次循环,继续下次循环

break:跳出所在的循环

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script>
        while (true) {
            let str = prompt('如果是我DJ,你还爱我吗?')
            if (str === '爱') {
                alert('我也爱你啊~~')
                break
            }
        }
    </script>
</body>

</html>

综合案例

页面弹框

需求:页面弹出对话框,‘你爱我吗’,如果输入‘爱’,则结束,否则一直弹出对话框

分析:

①:循环条件永远为真,一直弹出对话框

②:循环的时候,重新让用户输入

③:如果用户输入的是: 爱,则退出循环 (break)

<!DOCTYPE html>
<html lang="en">

<head>
</head>

<body>
  <script>
    //定义一个初始金额变量
    let money = 100

    //若用户不选择退出,则一直跳出弹框让用户进行操作
    while (1) {
      //定义一个变量获取用户想要的操作序号
      let enterNum = prompt(`请选择您的操作:
          1.取款
          2.存款
          3.查看余额
          4.退出`) * 1
      //如果选择4退出,则退出while循环
      if (enterNum == 4) {
        break//退出循环
      }
      switch (enterNum) {
        case 1: {
          let outMoney = prompt('请输入你要取的金额:') * 1
          //判断金额不能小于已有金额,如果小于则跳出警示框
          if (outMoney <= money) {
            money -= outMoney
          } else {
            alert(`您当前存款为${money}元,请输入小于它的取款金额`)
          }
          break
        }
        case 2: {
          let inMoney = prompt('请输入你要存的金额:') * 1
          money += inMoney
          break
        }
        case 3: {
          alert(`您当前存款为${money}元`)
          break
        }
      }
    }
  </script>
</body>

</html>