JS之隐式转换与布尔判定

大家思考一下

\] + \[ \]= ? **答案是空字符串** 为什么呢? **当做加法运算的时候,发现左右两端存在非原始类型,也就是引用类型对象,就会对对象做隐式类型转换** 如何执行的?或者说怎么查找的? 第一步,会去对象中查找是否有 **\[Symbol.toPrimitive\]** ```javascript let obj = { [Symbol.toPrimitive]() { return 123 //如果返回引用数据类型 下面打印会报错 } } console.log(obj + 1); //124 ``` **如果不存在就进入第二步,查找是否存在valueOf** ```javascript let obj = { valueOf() { return 1 } } console.log(obj + 1); //2 ``` **如果valueOf返回的也是引用数据类型就会进入第三步,toString()** ```javascript let obj = { valueOf() { return [] //如果返回引用数据类型就会进入第三步 }, toString() { return 1 } } console.log(obj + 1); //2 ``` **所有为什么\[ \] + \[ \] = " " 呢? 因为它依次查找,找到最后发现是 \[ \] 就会执行最后一步 \[ \].toString()也就是空字符串** **那\[ \] + !\[ \] = ? 答案是false** 这个是布尔判定 不是类型转换 **大家熟知的布尔为false的有:NaN Undefined Null " " 0 false** 除了这些东西 其它都为true !\[ \] 为false 空字符串 + false = false ```javascript console.log([] + ![]);//false ``` ![在这里插入图片描述](https://file.jishuzhan.net/article/1751855834104598529/c5eea0b13ec30180cb0299856660fda8.webp) **感谢大家的阅读,如有不对的地方,可以向我提出,感谢大家!**

相关推荐
wshzd1 分钟前
LLM之Agent(二十九)|LangChain 1.0核心组件介绍
前端·javascript·langchain
程序猿_极客5 分钟前
Vue 2脚手架从入门到实战核心知识点全解析(day6):从工程结构到高级通信(附代码讲解)
前端·javascript·vue.js·vue2学习笔记
一只小阿乐16 分钟前
vue3 使用v-model开发弹窗组件
javascript·vue.js·elementui
web加加20 分钟前
vue3 +vite项目页面防f12,防打开控制台
前端·javascript·vue.js
范纹杉想快点毕业23 分钟前
《嵌入式开发硬核指南:91问一次讲透底层到架构》
java·开发语言·数据库·单片机·嵌入式硬件·mongodb
毕设源码-邱学长27 分钟前
【开题答辩全过程】以 基于Python的Bilibili平台数据分析与可视化实现为例,包含答辩的问题和答案
开发语言·python·数据分析
芝麻馅汤圆儿29 分钟前
c文件编译
c语言·开发语言
千疑千寻~31 分钟前
【Qt】QT的程序打包
开发语言·qt
咚咚王者38 分钟前
人工智能之编程进阶 Python高级:第十一章 过渡项目
开发语言·人工智能·python
大G的笔记本42 分钟前
Java常见设计模式面试题(高频)
java·开发语言·设计模式