6.3JS运算2

1.运算符
    逻辑运算符
        !
            - 非运算可以对一个布尔值进行取反,true变false false边true
            - 当对非布尔值使用!时,会先将其转换为布尔值然后再取反
            - 我们可以利用!来将其他的数据类型转换为布尔值
        
        &&
            - &&可以对符号两侧的值进行与运算
            - 只有两端的值都为true时,才会返回true。只要有一个false就会返回false。
            - 与是一个短路的与,如果第一个值是false,则不再检查第二个值
            - 对于非布尔值,它会将其转换为布尔值然后做运算,并返回原值
            - 规则:
                    1.如果第一个值为false,则返回第一个值
                    2.如果第一个值为true,则返回第二个值
        
        ||
            - ||可以对符号两侧的值进行或运算
            - 只有两端都是false时,才会返回false。只要有一个true,就会返回true。
            - 或是一个短路的或,如果第一个值是true,则不再检查第二个值
            - 对于非布尔值,它会将其转换为布尔值然后做运算,并返回原值
            - 规则:    
                    1.如果第一个值为true,则返回第一个值
                    2.如果第一个值为false,则返回第二个值
                
    赋值运算符
        = 
            - 可以将符号右侧的值赋值给左侧变量
            
        +=
            - a += 5 相当于 a = a+5
            - var str = "hello";  str += "world";
            
        -=
            - a -= 5  相当于 a = a-5
            
        *=
            - a *= 5 相当于 a = a*5
            
        /=
            - a /= 5 相当于 a = a/5    
    
        %=
            - a %= 5 相当于 a = a%5    
            
            
    关系运算符
        - 关系运算符用来比较两个值之间的大小关系的
            >
            >=
            <
            <=
        - 关系运算符的规则和数学中一致,用来比较两个值之间的关系,
            如果关系成立则返回true,关系不成立则返回false。
        - 如果比较的两个值是非数值,会将其转换为Number然后再比较。
        - 如果比较的两个值都是字符串,此时会比较字符串的Unicode编码,而不会转换为Number。

    相等运算符
        ==
            - 相等,判断左右两个值是否相等,如果相等返回true,如果不等返回false
            - 相等会自动对两个值进行类型转换,如果对不同的类型进行比较,会将其转换为相同的类型然后再比较,
                转换后相等它也会返回true
        !=
            - 不等,判断左右两个值是否不等,如果不等则返回true,如果相等则返回false
            - 不等也会做自动的类型转换。
            
        ===
            - 全等,判断左右两个值是否全等,它和相等类似,只不过它不会进行自动的类型转换,
                如果两个值的类型不同,则直接返回false
                
        !==
            - 不全等,和不等类似,但是它不会进行自动的类型转换,如果两个值的类型不同,它会直接返回true
            
        特殊的值:
            - null和undefined
                - 由于undefined衍生自null,所以null == undefined 会返回true。
                    但是 null === undefined 会返回false。
                    
            - NaN
                - NaN不与任何值相等,报告它自身 NaN == NaN //false
                
            - 判断一个值是否是NaN
                - 使用isNaN()函数
                
    三元运算符:
        ?:
            - 语法:条件表达式?语句1:语句2;
            - 执行流程:
                先对条件表达式求值判断,
                    如果判断结果为true,则执行语句1,并返回执行结果
                    如果判断结果为false,则执行语句2,并返回执行结果
                    
    优先级:
        - 和数学中一样,JS中的运算符也是具有优先级的,
            比如 先乘除 后加减 先与 后或
        - 具体的优先级可以参考优先级的表格,在表格中越靠上的优先级越高,
            优先级越高的越优先计算,优先级相同的,从左往右计算。
        - 优先级不需要记忆,如果越到拿不准的,使用()来改变优先级。

2.流程控制语句
    - 程序都是自上向下的顺序执行的,
        通过流程控制语句可以改变程序执行的顺序,或者反复的执行某一段的程序。
    - 分类:
        1.条件判断语句
        2.条件分支语句
        3.循环语句
        
    条件判断语句
        - 条件判断语句也称为if语句
        - 语法一:
            if(条件表达式){
                语句...
            }
            
            - 执行流程:
                if语句执行时,会先对条件表达式进行求值判断,
                    如果值为true,则执行if后的语句
                    如果值为false,则不执行
        
        - 语法二:
            if(条件表达式){
                语句...
            }else{
                语句...
            }
            
            - 执行流程:
                if...else语句执行时,会对条件表达式进行求值判断,
                    如果值为true,则执行if后的语句
                    如果值为false,则执行else后的语句
            
        - 语法三:
            if(条件表达式){
                语句...
            }else if(条件表达式){
                语句...
            }else if(条件表达式){
                语句...
            }else if(条件表达式){
                语句...
            }else{
                语句...
            }
            
            - 执行流程
                - if...else if...else语句执行时,会自上至下依次对条件表达式进行求值判断,
                    如果判断结果为true,则执行当前if后的语句,执行完成后语句结束。
                    如果判断结果为false,则继续向下判断,直到找到为true的为止。
                    如果所有的条件表达式都是false,则执行else后的语句

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值