装箱和拆箱(js的问题)

装箱:基本数据类型 -> 引用数据类型

html 复制代码
var num = 123;
var numObj = new Number(123);

console.log(typeof num) // number
console.log(typeof numObj) // object

拆箱:引用数据类型 -> 基本数据类型

html 复制代码
var numObj = new Number(123);

console.log(numObj.valueOf()) // 123

console.log(typeof numObj.valueOf()) // number

拆箱操作原理:

html 复制代码
内部执行

toPrimitive(input, type)
input 传入的值
type 值类型

1. 如果是原始类型的值直接返回
2. 如果不是,调用 input.valueOf() 是原始类型就返回
3. 如果不是,继续调用  input.toString() 是原始类型就返回
4. 报错
html 复制代码
valueOf()  有原始类型的值返回,没有返回对象本身
toString() 对象[object type] type:对象类型

例题1:

html 复制代码
console.log([] + [])
<empty string>

// 分析:
console.log([])
Array []

console.log([].valueOf())
Array []

console.log([].toString())
<empty string>

例题2:

html 复制代码
console.log([] + {})
[object Object]

// 分析:
console.log({}.valueOf())
{}

console.log({}.toString())
[object Object]

// 交换位置,{}可能被识别为代码块
console.log({} + [])
[object Object] 或 0

console.log(+ [])
0

console.log(+ '')
0

console.log(+ {})
NaN
相关推荐
yyyyyyykk3 分钟前
Java后端框架---Spring
java·开发语言·spring
玄【学生党】4 分钟前
【c++】介绍
开发语言·c++
喝旺仔la13 分钟前
Element Plus中button按钮相关大全
前端·javascript·vue.js
大熊程序猿19 分钟前
go 安装依赖超时
开发语言·后端·golang
谛凌20 分钟前
【Python123题库】#绘制温度曲线 #XRD谱图绘制 #态密度曲线绘制
开发语言·python·python123·python题库
z_鑫23 分钟前
C语言:冒泡排序的注意事项及具体实现
c语言·开发语言·数据结构·算法
柒@宝儿姐25 分钟前
Git的下载与安装
前端·javascript·vue.js·git·elementui·visual studio
Hiweir ·26 分钟前
机器翻译之数据处理
前端·人工智能·python·rnn·自然语言处理·nlp·机器翻译
吃海鲜的骆驼1 小时前
四、JVM原理-4.1、JVM介绍
java·开发语言·jvm·面试
pjx9871 小时前
JVM 执行引擎详解:理论与实践
开发语言·jvm