js:一元运算符、自增和自减、逻辑运算符、赋值运算符、关系运算符、Unicode编码、相等运算符、条件运算符、运算符的优先级

一元运算符:只需一个操作数

+正号:不会对数字产生影响

-负号:对数字进行符号取反

对非Number类型值,会先转为Number,再运算

+可用来将其他数据类型转为Number,作用类似于Number()函数

自增:使变量在自身的基础上加一

? ? ? ? ? 后++(a++):值等于原变量的值【先赋值后自增】

? ? ? ? ? 前++(++a):值等于新的值【先自增后赋值】

自减:使变量在自身基础上减一

? ? ? ? ? 后--(a--):值等于原变量的值【先赋值后自减】

? ? ? ? ? 前--(--a):值等于新的值【先自减后赋值】

逻辑运算符:!非;&&与;||或。

? ? ? ? !:取反操作,两次取反则值不变

对非布尔值操作时,会先转为布尔值,然后再取反

可对任意数据类型取两次反,将其转化为布尔类型,相当于Boolean()函数

? ? ? ? &&:对符号两侧值进行“与”运算并返回结果

两值中只要有一个值为false就返回false【遇false则false】

两值都为true才返回true

如果第一个值为false,则不会看第二个值

? ? ? ? ||:对符号两侧值进行“或”运算并返回结果

两值中只要有一个值为true就返回true【遇true则true】

两值都为false才返回false

如果第一个值为true,则不会看第二个值

? ? ? ? ? &&? ||对于非布尔值进行与或运算时,会先将其转换为布尔值再运算,并返回原值

&&如第一个值为true,则必然返回第二个值;第一个值为false则直接返回第一个值

||如第一个值为true,则直接返回第一个值;第一个值为false则返回第二个值

(从某种意义上来说&&在找false,||在找true)

赋值运算符:=(右侧赋值给左侧);+=;-=;*=;/=;%=

关系运算符:比较两个值之间的大小,关系成立返回true、不成立返回false

>;>=;<;<=。

非数值会将其转为数字再比较

若两侧都为字符串则不会转为数字,而会分别比较字符串中字符的Unicode编码

NaN与任何值比较,结果都是false

Unicode编码:

在js中用编码格式为:\u四位编码

在网页中编码格式为:&#编码

相等运算符:用来比较两个值是否相等,相等返回true,否则返回false(=为赋值,==为相等)

相等运算:用==比较;若两值类型不同会自动进行类型转换

不相等运算:用!=比较;也会自动进行类型转换

全等运算:用===判断;不会做自动的类型转换,若两值类型不同则直接返回false

不全等运算:用!==判断;不会做自动的类型转换,若两值类型不同则直接返回true

条件运算符(也叫三元运算符):

语法:条件表达式?语句1:语句2;

实行的流程:首先对表达式进行求值,若该值为true,则实行语句1;若false,则实行语句2

若表达式求值结果为非布尔值,会将其转换为布尔值然后再运算

{var max = a>b ? a : b;

max = max>c ? max : c;

console.log("max=" + max);}----->求三个数中的最大值

运算符的优先级:

1:.、[]、 new

2:()

3:++、 --

4:!、~、+(单目)、-(单目)、typeof、void、delete

5:%、*、/

6:+(双目)、-(双目)

7:<< 、 >>、 >>>

8:<、<=、>、>=

9:==、!==、===

10:&

11:^

12:|

13:&&

14:||

15:?:

16:=、+=、-=、*=、/=、%=、<<=、>>=、>>>=、&=、^=、|=

17:,

“,”可以分割多个语句,一般在声明多个变量时使用

ljh原创,请勿抄袭,谢谢

推荐阅读更多精彩内容