JS:关系运算符的隐式转化

Posted waytogo-hwd

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS:关系运算符的隐式转化相关的知识,希望对你有一定的参考价值。

JS:关系运算符的隐式转化

JS:关系运算符的隐式转化


关系运算符

> 、 >= 、 < 、<= 、 == 、 === 、!= 、 !==


1. 字符串,布尔值 和数字进行比较时,会先隐式的转化为数字类型,之后再比较

  • console.log("5" > 3); // true
  • console.log(true == 1); // true
  • console.log(false == 0); // true
  • console.log(true == 2); // false

2.字符串 和 字符串比较时,按照从左到右的顺序 比较 字符在码表(ASCII)中的大小

  • console.log(5 > 12); //false
  • console.log("5" > 12); //false
  • console.log("5" > "12"); //true
  • console.log("15" > "12"); //true
  • console.log("1" > "12"); //false

3. null 和 undefined 在和数字比较时

3.1 如果遇到 == 不会进行在转化,没有可比性(false)

  • console.log(null == 0); // false
  • console.log(null == 1);// false
  • console.log(null == -1);// false

3.2 如果遇到 > >= < <= 会隐式的转化为数字(null转化为 0 ,undefined 转化为 NaN),可以进行比较

  • console.log(null >= 0); // true
  • console.log(null <= 0); // true
  • console.log(null > -5); // true
  • 因为undefined转化为NaN 所以undefined的判断都是false
  • console.log(undefined == 0); // false
  • console.log(undefined >= 0); // false
  • console.log(undefined <= 0); // false

4. null 和 undefined 在数值上是相等的(官方规定),类型上不相同

  • var a; // undefined
    var b = null;
    console.log(a == b); //undefiend == null => true
    console.log(a === b); //undefiend === null => false

5. NaN 和 任何值 都不相等

  • console.log(NaN == NaN); //false
  • console.log("NaN" == "NaN"); //true



以上是关于JS:关系运算符的隐式转化的主要内容,如果未能解决你的问题,请参考以下文章

js中的隐式类型转化

用户定义的隐式转换运算符和重载解析

使用接口的隐式运算符

js中有趣的隐式转化结构

使用 boost::variant C++ 的隐式运算符重载

JavaScript数据类型的隐式转换