JS运算符与逻辑分支

JS运算符与逻辑分支

JS运算符

1.一元运算符 —— 只能操作一个值的运算符

()前面不能直接写++

console.log(++(a--)); //() 不能和++ 一起使用
2.关系运算符
  • 字符串和数值进行比较(字符串会自动转为数值)

    console.log(1>2);//false
    console.log('123'>213);//false 自动转为number
    console.log('123A'>213);//false 自动转为number如果不能转就会出现NaN
    
  • 出现NaN 一般都是false

console.log(NaN==NaN);//false
  • undefined是null的派生所以对应的值是相等的
console.log(undefined==null);//true
console.log(undefined===null);//false
  • 字符串和字符串进行比较 (第一位ASCII码比较 第二位次之A 65 a 97)
console.log('a'>'b');//false
console.log('a'<'b');//true
console.log('bAA'<'azz');//false
  • 布尔类型的值和null进行比较(出现NaN是false)
console.log(true>null);//true
console.log(true>undefined);//false
  • 会先转换再进行比较
//恒等 这个俩个内容是一个内容
console.log(Number(true)==1); //true
console.log(Number(true)===1); //true
console.log(Boolean(0)===false); //true
  • null值及undefined跟0进行比较
console.log(undefined == 0);//NaN false
//null是空对象引用 对应的是一个引用类型 引用类型比较的是地址 null和0进行比较
console.log(null == 0); //false
3.逻辑运算符
&& 短路与 &断路与 || 短路或 |断路或 !

1.&& 所有的同时满足才为真 && 只要前面有一个是假后面的就不会看了 & 看完全部

var a=10,b=20,c=30
console.log(a>b && b<c);//false
console.log(c>b && b<c);//true

2.|| 有一个是true就是true 前面只要出现了true 就不看后面的 | 看完全部

var a=10,b=20,c=30
console.log(c>b || a>b);//true

3.! 取反

var a=10,b=20,c=30
console.log(!c>b || a>b); //false
console.log(!(c>b || a>b)); //false

4.|| 常用

  • 有一个是true 取true

    console.log(a>b || 20); //20
    var i = 0 || 10
    console.log(i);
    
  • 如果俩个都是false 取最后一个

    var str = undefined || ''
    console.log(str);
    
  • 如果俩个都是true的情况下 取第一个为true的

    var str1 = "A" || "B"
    console.log(str1);//A
    var str2 = "" || 'false' || 'true'
    console.log(str2);//false字符串
    

5.&& 如果出现false 直接取false 如果全是true 取最后一个

var str4 = 10 && 20 //20
var str5 = undefined && '' //undefined
var str6 = !123 //false
console.log(str4);
console.log(str5);
console.log(str6);

6.三目运算 逻辑运算优先级会高于三目运算符

var str3 = (10 > 20 ? '' : '123') || (30 > 20 ? '' : '456')
console.log(str3);//123
4.表达式的概念

由运算符和操作数(变量或常量)组成的式子

  • 算术运算符组成的式子叫算术表达式, 如:2+3;
  • 关系运算符组成的式子叫关系表达式或者条件表达式, 如:a>5;
  • 逻辑运算符组成的式子叫做逻辑表达式, 如:a&&b
运算符的优先级(由上到下执行)
运算符 描述
. [] () 对象成员存取、数组下标、函数调用等
++ -- ~ ! delete new typeof void 一元运算符
*** / %** 乘法、除法、去模
+ - + 加法、减法、字符串连接
<< >> >>> 移位
< <= > >= instanceof 关系比较、检测类实例
== != === !== 恒等(全等)
& 位与
^ 位异或
| 位或
&& 逻辑与
|| 逻辑或
?: 三元条件
= x= 赋值、运算赋值
, 多重赋值、数组元素

逻辑分支

程序的三大流程控制:

​ 我们的计算机在执行一个程序的时候,最基本的方式是一条语句接一条语句的执行。但不可能所有的问题都能用顺序执行方式就能解决,总会有一些跳转。
​ 采用结构化的程序设计,可以大大提高开发程序的速度、提高程序的可读性、程序运行的速度和效率。
​ 结构化程序是由若干个基本结构组合而成,每一个结构可以包含若干条语句和其它基本结构。共有三种基本结构:

顺序:从上朝下执行的代码就是顺序
分支(选择):根据不同的情况,执行对应代码
循环:重复做一件事情

IF

条件控制语句

if 如果 —— 第一个条件

else if 如果 —— 第二个条件(无限加)

else 否则 ——不满足上面的情况(只有一个)

if 和 else if 同时满足的情况下 他只会进入第一个满足的条件

if(条件表达式(boolean类型的值 如果当前这个不是一个boolean的值他会自动转成boolean类型)){
	需要执行的代码
}else if(条件表达式){
	需要执行的代码
}else{ //上面的都不满足的情况下
	需要执行的代码
}
var a=10,b=20
//从上到下的顺序进行的 上面只有一个进入的下面的内容就不会执行了
if(a>b){
    console.log('我是a的值为'+a)
}else if(a==b){
    console.log('我是b的值为'+b)
}else if(a<b){
    console.log('a的值小于b的值')
}else{
    console.log('上面的都不满足')
}

示例

//参军条件 身高大于170
var height = prompt('请输入你的身高') //string值的
if(!(height*1)){//NaN 
    console.log('兄弟 绕我一命!!');
}else if(height>230 || height<50){
    console.log('恭喜你超出人类标准');
}else if(height>170){//自动转为number类型
    console.log('恭喜你满足条件了');
}else{
    console.log('当前不满足条件');
}

注:当前只有一句代码的时候可以省略对应的{} ,多行代码是不行的

IF嵌套 —— 保证良好的缩进 保证可读性
// 求y的值
var x = prompt()
var y
//可能不是数值
//提取条件优秀级 先找出问题的条件 再找大的条件 再找小的条件
if(Number(x) || x == 0){
    if(x<0){
        y = -1
    }else if(x==0){
        y = 0
    }else{
        y = 1
    }
    console.log(y);
}else{
    console.log('您的输入有误');
}

注: 嵌套if时, 内层的每一对if-else代码要缩进且对齐;编写代码时,else要与最近的if配对。

switch

switch(表达式) {
     case 常量1: 语句; break;
     case 常量2: 语句; break;
	…
     case 常量n: 语句; break;
     default:语句; break;
}

​ 表达式的结果等于哪个case的常量,则执行其后的语句,执行完break就跳出switch结构,都不满足则执行default的语句。

break的作用:是跳出switch结构,如果没有break,则继续执行下面分支的的语句(而不进行判断)。注意case穿透,要加break

​ switch的应用场景: 表达式为固定值, 不能判断范围。

示例

示例

var grade = prompt()
switch(grade){
    case 'A':
        console.log('80-100');
        break
    case 'B':
        console.log('70-79');
        break
    case 'C':
        console.log('60-69');
        break
    case 'D':
        console.log('<60');
        break
    default:
        console.log('error');
}

posted @ 2022-07-26 20:06  CHENNGE  阅读(37)  评论(0)    收藏  举报