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.运算符优先级
- 小括号 ()
- 一元运算符 ++ – !
- 算数运算符 先/ % 后±*
- 关系 > >= < <=
- 相等 == != === !==
- 逻辑运算符 先&&后||
- 赋值运算符 =
- 逗号运算符 ,
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