在 JavaScript 中,基本类型是没有属性和方法的,但是为了便于操作基本类型的值,在调用基本 类型的属性或方法时 JavaScript 会在后台隐式地将基本类型的值转换为对象。
const a = "abc"; a.length; // 3 a.toUpperCase(); // "ABC"
在访问 'abc'.length 时, JavaScript 将 'abc' 在后台转换成 String('abc') ,然后再访问其 length 属性。
//在访问 'abc'.length 时, JavaScript 将 'abc' 在后台转换成 String('abc') ,然后再访问其length 属性。
var a = 'abc'
Object(a) // String {"abc"}
//也可以使用 valueOf 方法将包装类型倒转成基本类型:
var a = 'abc'
var b = Object(a)
var c = b.valueOf() // 'abc'
//看看如下代码会打印出什么:
var a = new Boolean( false ); //a成了一个对象
if (!a) {
console.log( "Oops" ); // never runs
}
//答案是什么都不会打印,因为虽然包裹的基本类型是 false ,但是 false 被包裹成包装类型后就成了对象,所以其非值为 false ,所以循环体中的内容不会运行。

在JavaScript中,基本类型没有属性和方法,但调用时会隐式转换为对象。例如,字符串abc在访问length属性时会被转换为String(abc)。同样,通过valueOf方法可将包装类型转换回基本类型。当布尔值false被封装为对象后,其在逻辑表达式中仍被视为false。

被折叠的 条评论
为什么被折叠?



