for in循环i的数据类型

本文探讨了JavaScript中for循环与for...in循环在处理数组时的不同表现,特别是循环变量的数据类型差异导致的问题,并提供了相应的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在某一个情况下,有时候使用 for 循环时,需要使用当前循环到的 i 这个变量的值进行一些运算操作,比如通过计算再赋值,加入数组等等。比如:

var arr=[1,2,3];
var arr2=[];
for(var i=0;i<arr.length;i++){
    arr2[i+1]=arr[i];
}
arr2[0]=0;
console.log(arr2);//1,2,3,4
console.log(arr2.length);//4

这个结果是正常的,但许多用于在数组中的循环我们都很喜欢用 for in 循环,这时候再进行这样的操作就会出现问题:

var arr=[1,2,3];
var arr2=[];
for(var i in arr){
    arr2[i+1]=arr[i];
}
arr2[0]=0;
console.log(arr2);//[0, undefined × 10, 2, undefined × 9, 3, 01: 1]
console.log(arr2.length);//22

出现这种情况的原因是:在 for in 循环中,循环的变量 i 的数据类型是string

var arr=[1,2,3];
for(var i in arr){
    console.log(i);
    console.log(typeof i);//string
}
for(var i=0;i<arr.length;i++){
    console.log(i);
    console.log(typeof i);//number
}

JavaScript是弱数据类型,0+”1”=”01”;”2”+6=”26”,会自动转换数据类型。可以用下面的方法解决:
复制数组,使用普通for循环解决

for(var i=0;i<arr.length;i++){
    arr2[i+1]=arr[i];
} 

或者对 for in 循环中的 i 使用 parseInt() 转换数据类型后再进行运算。

for(var i in arr){
    arr2[parseInt(i)+1]=arr[i];
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值