JS中==和===的区别

  • JS中==和===的区别已关闭评论
  • 19 次浏览
  • A+
所属分类:Web前端
摘要

使用双等号进行相等判断时,如果两边的类型不一致,则会进行强制类型转化后再进行比较;
使用三等号进行相等判断时,如果两边的类型不一致时,不会做强制类型准换,直接返回 false;


== 和 ===的区别

使用双等号进行相等判断时,如果两边的类型不一致,则会进行强制类型转化后再进行比较;
使用三等号进行相等判断时,如果两边的类型不一致时,不会做强制类型准换,直接返回 false;

==的判断流程

  1. 首先判断两者类型是否相同,相同的话就比较两者的大小;类型不相同的话,就会进行类型转换。
  2. 判断是否在对比 nullundefined,是的话就会返回 true
  3. 判断两者类型是否为 String 和 Number,是的话就会将字符串转换为 number
  4. 判断其中一方是否为 Boolean,是的话就会把 Boolean 转为 Number 再进行判断。
  5. 判断其中一方是否为 Object 且另一方为 String、Number 或者 Symbol,是的话就会把 Object 转为原始类型再进行判断。

强制类型转换规则

string转number

String 类型的值转换如同使用 Number() 函数进行转换,如果包含非数字值则转换为 NaN,空字符串为 0。

  • 如果字符串包含数值字符,包括数值字符前面带加、减号的情况,则转换为一个十进制数值。如果数值前有前置0,会忽略。
  • 如果字符串包含有效的浮点值格式,则会转换为相应的浮点值(同样,忽略前面的零)。
  • 如果字符串包含有效的十六进制格式如"0xf",则会转换为与该十六进制值对应的十进制整数值。
  • 如果是空字符串(不包含字符),则返回0。
  • 如果字符串包含除上述情况之外的其他字符,则返回NaN。

Boolean转Number

true转1,false转0。其中Boolean为false的值有null、undefined、false、+0、-0、NaN、空字符串

对象转基本类型

对象在转换基本类型时,会调用 valueOf 和 toString。如果倾向于将对象转换为Number,则调用valueOf();倾向于转换为String类型,则调用toString()。

  1. 普通对象:valueOf方法返回对象本身,而toString方法返回"[object ObjectName]";
  2. Array:valueOf方法放回数组本身。而toString方法将 Array 的每个元素转换为字符串,并将它们依次连接起来,两个元素之间用英文逗号作为分隔符进行拼接
  3. Date:valueOf方法放回时间戳。而toString方法返回日期的文本表示。
  4. Function:valueOf方法返回方法本身。而toString方法返回"function functionname() { [native code] }"。