JS类型转换:一场隐式与显式的"变形记"

各位前端er,今天咱们来聊聊JS中最让人头疼又不得不爱的话题------类型转换。这玩意儿就像JS里的"七十二变",有时候能帮你化险为夷,有时候却能让你debug到怀疑人生。

== vs ===:马虎鬼与强迫症的对决

==就像个马虎的老大哥,只要值差不多就点头:1 == '1'?行!0 == false?没问题!甚至null == undefined?都是好兄弟!

===则是个十足的强迫症患者,必须值和类型完全一样才罢休:1 === '1'?抱歉,类型不同免谈!0 === false?一边儿去,布尔不是数字!

类型转换的两种打开方式

1. 显式转换:光明正大的变形

这就像明着说"我要变身":

  • Boolean(x):除了0''nullundefinedNaNfalse,其他通通变true
  • Number(x):字符串转数字有一套严格规则,详情请参考ES5规范(反正转不了就变NaN
  • String(x):万物皆可转字符串,对象会调用toString()

2. 隐式转换:偷偷摸摸的变身

这才是JS的精髓(坑)所在!你永远不知道什么时候它就给你变了:

  • 四则运算+只要有一个字符串就变成拼接,其他运算符默默转数字
  • 判断语句ifwhile里的条件会偷偷转布尔
  • 比较操作符==>=等会触发各种隐式转换

ToPrimitive:对象变形的终极法则

对象想转原始类型?得走ToPrimitive流程:

  • 转字符串时:先调用toString(),不行再调用valueOf()
  • 转数字时:先调用valueOf(),不行再调用toString()
  • 都不行?抛出TypeError,跟你急眼!

避坑指南:类型转换的那些坑

  1. [] == ![]:结果是true!因为![]false[]转数字是00 == false成立
  2. NaN == NaN:结果是false!NaN谁都不认识,包括它自己
  3. {}.toString():返回"[object Object]",而不是`
相关推荐
北海-cherish2 小时前
vue中的 watchEffect、watchAsyncEffect、watchPostEffect的区别
前端·javascript·vue.js
AALoveTouch2 小时前
网球馆自动预约系统的反调试
javascript·网络
新中地GIS开发老师5 小时前
Cesium 军事标绘入门:用 Cesium-Plot-JS 快速实现标绘功能
前端·javascript·arcgis·cesium·gis开发·地理信息科学
Superxpang5 小时前
前端性能优化
前端·javascript·vue.js·性能优化
左手吻左脸。5 小时前
解决el-select因为弹出层层级问题,不展示下拉选
javascript·vue.js·elementui
李白的故乡5 小时前
el-tree-select名字
javascript·vue.js·ecmascript
Rysxt_5 小时前
Element Plus 入门教程:从零开始构建 Vue 3 界面
前端·javascript·vue.js
隐含5 小时前
对于el-table中自定义表头中添加el-popover会弹出两个的解决方案,分别针对固定列和非固定列来隐藏最后一个浮框。
前端·javascript·vue.js
你的人类朋友5 小时前
先用js快速开发,后续引入ts是否是一个好的实践?
前端·javascript·后端
知识分享小能手5 小时前
微信小程序入门学习教程,从入门到精通,微信小程序核心 API 详解与案例(13)
前端·javascript·学习·react.js·微信小程序·小程序·vue