为什么它能用length?原来是包装类这小子搞鬼

在 JavaScript 中,原始值是不能具有属性和方法的,因为属性和方法是对象独有的。但是 JavaScript 提供了包装类的机制,使得我们可以在原始值上使用属性和方法。

当我们访问原始类型的属性或方法时,JavaScript 会临时使用包装类来实现这一操作,然后立即销毁这个临时对象。例如,当我们使用 . 操作符访问字符串的 length 属性时,JavaScript 会将字符串转换为临时的包装类对象 ,获取其 length 属性值,然后立即销毁这个临时对象。

包装类

包装类提供了一种方便的方式来操作原始值,但需要注意保持包装类和原始类型之间的转换。如果我们对原始值进行修改,不会影响到原始值本身。

js 复制代码
 var num = 123
 num.a = 'hello'
 console.log(num.a);    

这段代码执行不会报错,会打印undefined,那这是为什么呢?我们继续往下看

js 复制代码
 var num = 123   //String()  Number()  Boolean()  Object()  Arry()  Date()  内部函数
 num.a = 'hello' 
// delete num.a
 console.log(num.a);   

没有报错是因为var num = 123解读成var num = new Number(123);但是num是一个原始值,会有一个delete删除num.a,所以打印undefined(访问对象不存在的属性时也会打印undefined)

上一篇对象文章juejin.cn/post/730124...说明 var num = new Number(123);new将num变成了对象 ,那么 num.a = 'hello' 合情合理,可以拿到hello。

但是它又可以乘法(对象是不能使用乘除等操作) ?
console.log(num*2) //打印246

说明num本质上还是原始类型

包装类考点

原始值身上能有属性和方法吗? 没有,为什么还能见到原始值身上有属性和方法?

js 复制代码
var arr =[1,2,3,4]
arr.length = 2
 console.log(arr); //可以打印数组[1,2] 
 var str = 'abcd'  
 console.log(str.length); //4
}

字符串str是原始类型,没有length属性,为什么可以打印4?

数组可以通过arr.length = 2改变数组长度,那字符串str可以吗?

js 复制代码
var arr =[1,2,3,4]
arr.length = 2
// console.log(arr);    //[1,2]
 var str = 'abcd'  
str.length = 2

console.log(str.length);

很显然字符串不能通过str.length = 2改变字符串长度。

那下面解决运行打印4的问题

js 复制代码
var arr =[1,2,3,4]
arr.length = 2
// console.log(arr);    //[1,2]
 var str = 'abcd'  
str.length = 2
// new String('abcd').length = 2  
console.log(str.length);//上面length属于 new String('abcd').length
// 构造函数天生有这个
//function String(s){
  //  this.length = 0
//}

字符串在调用str.length = 2时会产生new String('abcd').length = 2(包装类)这样一个代码,length属于它,同样它在调用后有一个delete删除它。

这篇文章juejin.cn/post/730124...讲到了String为实例对象==this,而构造函数会创建function String(s){this.length = 0}fun会遍历s,有几个就有多长,最后再把this.length返回,这样字符串就可以拥有长度了。这全都是包装类在搞鬼

相关推荐
NiceCloud喜云7 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby8 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
GISer_Jing8 小时前
Three.js着色器编译机制深度解析
javascript·webgl·着色器
丷丩8 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
油炸自行车8 小时前
Claude Code 错误:API Error: 400 Failed to deserialize the JSON body into the
开发语言·javascript·json·trae·claude code·api error 400
Front思9 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫11 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。12 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星12 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒12 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端