美文网首页
JS重点之运算符以及运算符优先级

JS重点之运算符以及运算符优先级

作者: MrOldK | 来源:发表于2018-12-07 12:08 被阅读11次

    JavaScript中的运算符优先级是一套规则。该规则在计算表达式时控制运算符执行的顺序。具有较高优先级的运算符先于较低优先级的运算符执行。例如,乘法的执行先于加法。

    算数运算符:

    加+,减—,乘*,除/,求余%,加加++,减减——,

    加减乘除求余运算与数学上的用法完全一样。

    不过,加号+还有连接字符串的作用,其他运算符还可以将字符串数字转换成数值型,参见JavaScript中数据类型转换总结中的隐式转换部分。

    ++,——分为前置和后置,前置表示在使用该变量之前加/减1,后置表示在使用之后加/减1。

    逻辑运算符:

    1.&&: 与运算, 当与运算的两个内容都为true的时候,结果为true,只要有一个内容为false,结果都是false,&& 可以读作“并且”

    2.||: 或运算, 当或运算的两个内容都为false的时候,结果为false,只要有一个内容为true,结果都是true,|| 可以读作“或者”

    3.!: 非运算, 取反运算,当内容为true时,取反结果为false,当内容为false时,取反结果为true
    补充:

    &&与||的其他用法

    &&

    如果两个操作数都不是布尔类型

    且两个数值转换成布尔类型都是true,返回第二个操作数

    如果有一个操作数转换成布尔类型是false,返回这个数

    var b=undefined&&null

    console.log(b);

    返回undefined

    ||

    如果两个操作数都不是布尔类型

    第一个数转换成布尔类型为true,则不往下看,返回第一个数

    如果第二个数转换成布尔类型为true,则返回第二个数值。

    比较运算符:

    , <, >= ,<=, == ,!=,===,!==

    , <, >= ,<=和数学里表示的含义完全一样。下面四个运算符刚开始接触会有点迷惑。

    == 相等操作符

    如果两个操作数相等,则返回 true。

    != 不相等操作符

    如果两个操作数不相等,则返回 true。

    这两个操作符都会先转换操作数(通常称为强制转型),然后再比较它们的相等性。在转换不同的数据类型时,相等和不相等操作符遵循下列基本规则:

    1、 如果有一个操作数是布尔值,则在比较相等性之前先将其转换为数值——false 转换为 0,而true 转换为 1;

    2、如果一个操作数是字符串,另一个操作数是数值,在比较相等性之前先将字符串转换为数值;
    3、 如果一个操作数是对象,另一个操作数不是,则调用对象的 valueOf()方法,用得到的基本类型值按照前面的规则进行比较;
    这两个操作符在进行比较时则要遵循下列规则。
    1、 null 和 undefined 是相等的。
    2、 要比较相等性之前,不能将 null 和 undefined 转换成其他任何值。
    3、 如果有一个操作数是 NaN,则相等操作符返回 false,而不相等操作符返回 true。重要提示:
    即使两个操作数都是 NaN,相等操作符也返回 false;因为按照规则, NaN 不等于 NaN。
    如果两个操作数都是对象,则比较它们是不是同一个对象。如果两个操作数都指向同一个对象,
    则相等操作符返回 true;否则,返回 false。

    下表列出了一些特殊情况及比较结果:

    表达式值 表达式值
    null == undefined true true == 1 true
    "NaN" == NaN false true == 2 false
    5 == NaN false undefined == 0 false
    NaN == NaN false null == 0 false
    NaN != NaN true "5"==5 true
    false == 0 true 。。。

    === 全等操作符

    在两个操作数未经转换就相等的情况下返回 true。即数值和类型都相同。

    var result1 = ("55" == 55); //true,因为转换后相等
    var result2 = ("55" === 55); //false,因为不同的数据类型不相等

    !== 不全等操作符

    在两个操作数未经转换就不相等的情况下返回 true。数据类型不同就不等。

    var result1 = ("55" != 55); //false,因为转换后相等
    var result2 = ("55" !== 55); //true,因为不同的数据类型不相等

    赋值运算符:

    =,+=,-=,*=,/=

    简单的赋值操作符由等于号(=)表示,其作用就是把右侧的值赋给左侧的变量。

    如果在等于号(=)前面再添加乘性操作符、加性操作符或位操作符,就可以完成复合赋值操作。

    num = num + 10; 等同于num += 10;

    设计这些操作符的主要目的就是简化赋值操作。使用它们不会带来任何性能的提升。

    三元运算符:

    ? :

    举个例子:

    var max = (num1 > num2) ? num1 : num2;
    在这个例子中, max 中将会保存一个最大的值。这个表达式的意思是:如果 num1 大于 num2(关系表达式返回 true),则将 num1 的值赋给 max;如果 num1 小于或等于 num2(关系表达式返回 false),则将 num2 的值赋给 max。

    位运算符:

    JavaScript也有位运算符,需要先转换成16进制数进行运算,在开发中好像还没有用到过,了解一下即可。

    javascript 中运算符优先级

    优先级 运算类型 关联性 运算符
    20 圆括号 n/a ( ... )
    19 成员访问 从左到右 ... . ...
    19 需计算的成员访问 从左到右 ...[ ... ]
    19 new (带参数列表) n/a new ... ( ... )
    19 函数调用 从左到右 ... ( ... )
    18 new (无参数列表) 从左到右 new ...
    17 后置递增(运算符在后) n/a ... ++
    17 后置递减(运算符在后) n/a ... --
    16 逻辑非 从右到左 ! ...
    16 按位非 从右到左 ~ ...
    16 一元加法 从右到左 + ...
    16 一元减法 从右到左 - ...
    16 前置递增 从右到左 ++ ...
    16 前置递减 从右到左 -- ...
    16 typeof 从右到左 typeof ...
    16 void 从右到左 void ...
    16 delete 从右到左 delete ...
    15 从右到左 ... ** ...
    14 乘法 从左到右 ... * ...
    14 除法 从左到右 ... / ...
    14 取模 从左到右 ... % ...
    13 加法 从左到右 ... + ...
    13 减法 从左到右 ... - ...
    12 按位左移 从左到右 ... << ...
    12 按位右移 从左到右 ... >> ...
    12 无符号右移 从左到右 ... >>> ...
    11 小于 从左到右 ... < ...
    11 小于等于 从左到右 ... <= ...
    11 大于 从左到右 ... > ...
    11 大于等于 从左到右 ... >= ...
    11 in 从左到右 ... in ...
    11 instanceof 从左到右 ... instanceof ...
    10 等号 从左到右 ... == ...
    10 非等号 从左到右 ... != ...
    10 全等号 从左到右 ... === ...
    10 非全等号 从左到右 ... !== ...
    9 按位与 从左到右 ... & ...
    8 按位异或 从左到右 ... ^ ...
    7 按位或 从左到右 ... | ...
    6 逻辑与 从左到右 ... && ...
    5 逻辑或 从左到右 ... || ...
    4 条件运算符 从右到左 ... ? ... : ...
    3 赋值 从右到左 ... = ...
    3 赋值 从右到左 ... += ...
    3 赋值 从右到左 ... -= ...
    3 赋值 从右到左 ... /= ...
    3 赋值 从右到左 ...% = ...
    3 赋值 从右到左 ... *= ...
    2 yield 从右到左 yield ...
    2 yield* 从右到左 yield* ...
    1 展开运算符 从左到右 ... ...
    0 逗号 从左到右 ... , ...

    相关文章

      网友评论

          本文标题:JS重点之运算符以及运算符优先级

          本文链接:https://www.haomeiwen.com/subject/jffthqtx.html