前端 JS 经典:双等号运算符的运算和转换规则

简介: 前端 JS 经典:双等号运算符的运算和转换规则

1. 运算规则

两端存在 NaN,返回 false

NaN == NaN; // false
NaN == 1; //false

undefinednull 只有与自身比较,或者相互比较时,才返回 true,和其他原始类型比较都返回 false。

undefined == null; // true
undefined == undefined; // true
null == null; // true

两端类型相同,比较值

1 == 2; // false
"yq" == "yqcoder"; // false

两端都是原始类型,转换成数字重新比较

0 == false; // true
"1" == 1; // true

一端是原始类型,一端是对象类型,把对象转换成原始类型后重新比较。

// 当有 [Symbol.toPrimitive] 符号时
let obj = {
  [Symbol.toPrimitive]() {
    return 2;
  },
};
obj == 2; // true
 
// 如果没有 [Symbol.toPrimitive]时, 先调用 valueOf() 拿原始值,如果没有再调用 toString() 拿原始值
let obj = {
  valueOf() {
    return {};
  },
  toString() {
    return 4;
  },
};
obj == 4; // true
 
// 使 obj == 1 && obj == 2 && obj == 3 成立
let obj = {
  count: 1,
  valueOf() {
    return this.count++;
  },
};
obj == 1 && obj == 2 && obj == 3; // true

2. 对象如何转原始类型

  1. 如果对象拥有[Symbol.toPrimitive]方法,调用该方法。若该方法能得到原始值,使用该原始值,若得不到原始值,抛出异常
  2. 调用对象的 valueOf 方法,若该方法能得到原始值,使用该原始值,若得不到原始值,进行下一步
  3. 调用对象的 toString 方法,若该方法能得到原始值,使用该原始值,若得不到原始值,抛出异常


目录
相关文章
|
24天前
|
JavaScript 前端开发 API
|
1月前
|
前端开发 JavaScript 数据可视化
58K star!这个让网页动起来的JS库,前端工程师直呼真香!
Anime.js 是一款轻量级但功能强大的JavaScript动画引擎,它能够以最简单的方式为网页元素添加令人惊艳的动效。这个项目在GitHub上已经获得58,000+星标,被广泛应用于电商页面、数据可视化、游戏开发等场景。
77 8
|
1月前
|
JavaScript 前端开发 容器
|
1月前
|
JavaScript 前端开发
|
1月前
|
存储 JavaScript 前端开发
|
1月前
|
移动开发 JavaScript 前端开发
|
1月前
|
存储 JavaScript 前端开发
|
1月前
|
JavaScript 前端开发
|
1月前
|
JavaScript 前端开发 开发者
|
7月前
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
562 14