Javascript运算符——算术运算符、三元运算符、自增 与 自减、比较运算符、逻辑运算符、= 与== 与 === 的区别

目录

1、算术运算符

2、三元运算符

3、自增 自减 / 递增 递减

4、比较运算符

5、逻辑运算符

6、双非 !! 作用讲解

运算符优先级

= 与== 与 === 的区别 


1、算术运算符


1. 加号 +(可用于字符串拼接)

加号两侧同时为数字,进行加法运算
加号两侧任何一侧为字符串,表示字符串拼接        (符号两侧要用空格隔开)

2.减号 -         3.乘号 *         4.除号 /        5.取余 %(只有+号会进行字符串的拼接,其余不会)

在进行减 乘 除 取余运算时:

符号两侧同时为数字进行对应的算术运算,若其中有一侧为非数字,则运算时会把该侧转换为数字,转换成功,进行对应的算术运算,转换失败,得到NaN(Not a Number非数字)    

  <script>
    /*
        + 加
        - 减
        * 乘
        / 除
         % 取余数
    */
    console.log(2 + 3);
    console.log(2 - 3);
    console.log(2 * 3);
    console.log(2 / 3);
    console.log(3 % 2);
    console.log(4 % 2); //余数0
  </script>
  1. +=  加等
  2. -= 减等
  3. *= 乘等
  4. /= 除等
  5. %= 
 var a = 10;
    a = a + 2;
    a += 2; // 输出12 和a=a+3结果相等,加等 
//其他几个用法相同

 字符拼接问题:

   console.log(2 + 4 + "=" + 6); //6=6
    console.log(4 + "=" + 3 + 1); //4=31 从左往右依次运算,先乘除,后加减,有括号先算括号内的
    console.log(4 + "=" + (3 + 1)); //4=4

2、三元运算符

语法: 条件        ?语句1        :语句2;

条件成立执行语句1,条件不成立执行语句2

<script>
   // 举例:
        var a = prompt('请输入数字'),
            b = prompt('请输入数字');
        a > b//条件
            ? document.write(a + b)//语句1
            : document.write(b + a);//语句2

    //举例
       var num = prompt("请输入一个数字", 0);
           num % 2 == 0 ? console.log(num + "是偶数") : console.log(num + "是奇数");
    </script>

3、自增 自减 / 递增 递减

递增(++)

递减(- -)

放在变量前面时,我们称为前置递增(递减)运算符

放在变量后面时,我们称为后置递增(递减)运算符

注意:递增和递减运算符必须和变量配合使用。

①前置递增运算符

++num num = num + 1

使用口诀:先自加,后返回值

var num = 10;
alert (++num + 10); // 21

②后置递增运算符

num ++ num = num +1

使用口诀:先返回原值,后自加

var num = 10;
alert(10 + num++); // 20

③小结

  • 前置递增和后置递增运算符可以简化代码的编写,让变量的值 + 1 比以前写法更简单
  • 单独使用时,运行结果相同,与其他代码联用时,执行结果会不同
  • 开发时,大多使用后置递增/减,并且代码独占一行

4、比较运算符

 除恒等外,其他比较过程都会进行类型转换 (但两侧同为字符串时不能自行完成类型转换

  • 大于>
  • 小于<
  • 小于等于<=
  • 大于等于>=
  • 等于==
  • 不等于!=
  • 恒等===

     返回布尔值

    console.log(5 > 8); //false
    console.log(5 < 8); //true
    console.log(5 >= 8); //false 
    console.log(5 <= 8); //true
    console.log(5 == 5); //true
    console.log(5 == "5"); //true 比较过程中也会进行类型转换
    console.log(5 === "5"); //false恒等,值和类型都要相等,不会进行类型转换
    console.log(1 == true); //true
    console.log(null == undefined); //true
    console.log(null == 0); //false
    console.log(0.1 + 0.2 == 0.3); //false

5、逻辑运算符

  •  逻辑与 &&   符号两侧同时为真,才为真,其他情况均为假
  • 逻辑或 ||   符号两侧同时为假才为假,其他情况均为真
  • 逻辑非 !非真即假 非假即真
  • !!双等号可进行类型转换  两个!!就可以将变量或属性转化为对应布尔值

6、双非 !! 作用讲解

javascript中的!!是逻辑"非非",即是在逻辑“非”的基础上再"非"一次。通过!或!!可以将很多类型转换成bool类型,再做其它判断。

使用javascript时,有时会在变量前面加上两个感叹号,这样做表示什么含义呢?Javascript中,!表示运算符“非”,如果变量不是布尔类型,会将变量自动转化为布尔类型,再取非,那么用两个!!就可以将变量转化为对应布尔值。

详情参考http://t.csdn.cn/0VkoT

    //逻辑与&&  符号两侧同时为真,才为真,其他情况均为假
    //短路
    console.log(true && true); //true
    console.log(true && false); //false
    console.log(false && false); //false
 
    //逻辑或||  符号两侧同时为假才为假,其他情况均为真
    console.log(true || true); //true
    console.log(true || false); //true
    console.log(false || false); //false
 
    // 逻辑非 ! 非真即假 非假即真
    console.log(!true); //false
    console.log(!false); //true

运算符优先级

优先级运算符顺序
1小括号()
2一元运算符++ - - !
3算数运算符先 * / % 后 + - (先乘除后加减)
4关系运算符> >= < <
5相等运算符==、   !=  、  ===、   !==
6逻辑运算符先  &&  后  ||
7赋值运算符=(赋值运算符优先级最低)
 

= 与== 与 === 的区别 

=表示赋值

== 表示相等 (值相等)
===表示恒等(类型和值都要相等)
js在比较的时候如果是 == 会先做类型转换,再判断值得大小,如果是===类型和值必须都相等。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值