1. 一元运算符
+ 正号: 正号不会对数字产生任何影响
- 负号: 负号可以对数字进行符号的取反
对于非Number类型的值,它会将先转换为Number,然后再运算
可以对一个其他的数据类型使用+,来将其转换为number,它的原理和Number()函数一样
2. 自增和自减
自增 ++
- 通过自增可以使变量在自身的基础上增加1
- 对于一个变量自增以后,原变量的值会立即自增1
- 自增分成两种:后++(a++) 和 前++(++a)
无论是a++还是++a,都会立即使原变量的值自增1
不同的是a++和++a的值不同
a++的值等于原变量的值(自增前的值)
++a的值等于新值 (自增后的值)
自减 --
- 通过自减可以使变量在自身的基础上减1
- 自减分成两种:后--(a--) 和 前--(--a)
无论是a--还是--a都会立即使原变量的值自减1
不同的是a-- 和 --a的值不同
a-- 是变量的原值 (自减前的值)
--a 是变量的新值 (自减以后的值)
3. 自增和自减的练习
var n1=10, n2=20;
var n = n1++;
console.log('n='+n);//10
console.log('n1='+n1);//11
n = ++n1;
console.log('n='+n);//12
console.log('n1='+n1);//12
n = n2--;
console.log('n='+n);//20
console.log('n2='+n2);//19
n = --n2;
console.log('n='+n);//18
console.log('n2='+n2);//18
4. 逻辑运算符
JS中为我们提供了三种逻辑运算符
! 非
- !可以用来对一个值进行非运算
- 所谓非运算就是值对一个布尔值进行取反操作,
true变false,false变true
- 如果对一个值进行两次取反,它不会变化
- 如果对非布尔值进行元素,则会将其转换为布尔值,然后再取反
所以我们可以利用该特点,来将一个其他的数据类型转换为布尔值
可以为一个任意数据类型取两次反,来将其转换为布尔值,原理和Boolean()函数一样
&& 与
- &&可以对符号两侧的值进行与运算并返回结果
- 运算规则
- 两个值中只要有一个值为false就返回false,
只有两个值都为true时,才会返回true
- JS中的“与”属于短路的与,
如果第一个值为false,则不会看第二个值
|| 或
- ||可以对符号两侧的值进行或运算并返回结果
- 运算规则:
- 两个值中只要有一个true,就返回true
如果两个值都为false,才返回false
- JS中的“或”属于短路的或
如果第一个值为true,则不会检查第二个值
5. 与或运算
&&:对符号两侧值进行“与”运算并返回结果
两值中只要有一个值为false就返回false【遇false则false】
两值都为true才返回true
如果第一个值为false,则不会看第二个值
||:对符号两侧值进行“或”运算并返回结果
两值中只要有一个值为true就返回true【遇true则true】
两值都为false才返回false
如果第一个值为true,则不会看第二个值
&& ||对于非布尔值进行与或运算时,会先将其转换为布尔值再运算,并返回原值
&&如第一个值为true,则必然返回第二个值;第一个值为false则直接返回第一个值
||如第一个值为true,则直接返回第一个值;第一个值为false则返回第二个值
(从某种意义上来说&&在找false,||在找true)
6. 赋值运算符
赋值运算符:=(右侧赋值给左侧);+=;-=;*=;/=;%=
7. 关系运算符
关系运算符:比较两个值之间的大小,关系成立返回true、不成立返回false
>;>=;<;<=。
非数值会将其转为数字再比较
若两侧都为字符串则不会转为数字,而会分别比较字符串中字符的Unicode编码
NaN与任何值比较,结果都是false
8. 字符实体
在js中用编码格式为:\u四位编码
在网页中编码格式为:&#编码
9. 相等运算符
相等运算符:用来比较两个值是否相等,相等返回true,否则返回false(=为赋值,==为相等)
相等运算:用==比较;若两值类型不同会自动进行类型转换
不相等运算:用!=比较;也会自动进行类型转换
全等运算:用===判断;不会做自动的类型转换,若两值类型不同则直接返回false
不全等运算:用!==判断;不会做自动的类型转换,若两值类型不同则直接返回true
10. 三目运算
语法:条件表达式?语句1:语句2;
执行的流程:首先对表达式进行求值,若该值为true,则执行语句1;若false,则执行语句2
若表达式求值结果为非布尔值,会将其转换为布尔值然后再运算
{var max = a>b ? a : b;
max = max>c ? max : c;
console.log("max=" + max);}----->求三个数中的最大值
11. 运算符的优先级
先乘除 后加减
在JS中有一个运算符优先级的表,
在表中越靠上优先级越高,优先级越高越优先计算
如果优先级一样,则从左往右计算
但是这个表我们并不需要记忆,如果遇到优先级不清楚
可以使用()来改变优先级
如果||的优先级高,或者两个一样高,则应该返回3
如果与的优先级高,则应该返回1