黑马pink-JavaScript笔记(4):运算符

1.运算符

也被称作操作符,用于实现赋值、比较和执行算术运算等功能的符号

JavaScript中常用的运算符

  • 算数运算符
  • 递增和递减运算符
  • 比较
  • 逻辑
  • 赋值

2.算数运算符

1.加、减、乘、除、取余
//浮点数 算数运算里面会有问题
console.log(0.1 + 0.2); // 0.30000000000000004
console.log(0.07 * 100); // 7.000000000000001
//我们不能直接拿着浮点数来进行相比较 是否相等
var num = 0.1 + 0.2;
console.log(num == 0.3); // false

注意:JS中的除法就是数学中的除法,不像Java会向下取整,例如5050/100=50.5

2.表达式和返回值
//  表达式是由数字、运算符、变量等组成的式子     
        console.log(1 + 1); //  1 + 1就是表达式    2 就是返回值

3.递增、递减运算符

//前置递增运算符:  ++/--写在变量的前面,先加1/减1,后返回值
var p = 10;
console.log(++p + 10);  //21
//后置递增运算符: ++/--写在变量的后面,先返回原值,后加1/减1 
var age = 10;
console.log(age++ + 10);  //20
console.log(age);  //11

4.比较运算符

//程序里面的等于符号 是 ==  默认转换数据类型 会把字符串型的数据转换为数字型 只要求值相等就可以
console.log(3 == 5); // false
console.log('pink老师' == '刘德华'); // flase
console.log(18 == 18); // true
console.log(18 == '18'); // true
console.log(18 != 18); // false
//程序里面有全等 一模一样  要求 两侧的值 还有 数据类型完全一致才可以 true
console.log(18 === 18);  //true
console.log(18 === '18'); // false

= 赋值

== 判断值相等

===全等:判断值和类型都相等

5.逻辑(布尔)运算符

逻辑运算符是用来进行布尔值运算的运算符,其返回值也是布尔值

1.用布尔值参与的逻辑运算 true && false == false
  • && 逻辑与 (and),两侧都为true ,结果才是 true ,只要有一侧为false ,结果就为false
  • || 逻辑或(or)两侧都为false,结果才是假 false,只要有一侧为true,结果就是true
  • ! 逻辑非(not)
console.log(3 > 5 && 3 > 2); // false
console.log(3 < 5 && 3 > 2); // true
console.log(3 > 5 || 3 > 2); // true 
console.log(3 > 5 || 3 < 2); // false
console.log(!true); // false
2.逻辑短路(中断)

原理:当有多个表达式(值)时,左边表达式值可以确定结果时,就不再继续运算右边的表达式的值

  • 逻辑与 表达式1 && 表达式2
    • 如果表达式1为,则返回表达式2
    • 如果表达式1为,则返回表达式1
console.log(123 && 456); // 456
console.log(0 && 456); //  0
console.log(0 && 1 + 2 && 456 * 56789); // 0
console.log('' && 1 + 2 && 456 * 56789); // ''
// 如果有空的或者否定的为假,0、''、null、undefined、NaN都是假
  • 逻辑或 表达式1 || 表达式2
    • 如果表达式1为,则返回表达式1
    • 如果表达式1为,则但会表达式2
console.log(123 || 456); // 123
console.log(123 || 456 || 456 + 123); // 123
console.log(0 || 456 || 456 + 123); // 456
  • 逻辑中断很重要 它会影响我们程序运行结果
var num = 0;
console.log(123 || num++);   //num++短路,没有执行
console.log(num); // 0

6.赋值运算符

var num = 10;
num += 5;  //  num = 15..00ar age = 2;
age *= 3;    //age = 6

7.运算符优先级

  1. 小括号 ()
  2. 一元运算符 ++ – !
  3. 算数运算符 / % 后±*
  4. 关系 > >= < <=
  5. 相等 == != === !==
  6. 逻辑运算符 先&&后||
  7. 赋值运算符 =
  8. 逗号运算符 ,
console.log(4 >= 6 || '人' != '阿凡达' && !(12 * 2 == 144) && true)  //true
//注意逻辑与的权重高于逻辑或

var num = 10;
console.log(5 == num / 2 && (2 + 2 * num).toString() === '22');  //true

var a = 3 > 5 && 2 < 7 && 3 == 4;  
console.log(a);   //false

var b = 3 <= 4 || 3 > 1 || 3 != 2; 
console.log(b);   //true

var c = 2 === "2";  
console.log(c);    //false

var d = !c || b && a; 
console.log(d);    //true
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值