js数组forEach方法的赋值问题

本文探讨了JavaScript中forEach方法在处理不同数据类型时的赋值行为。当数组元素为基本类型(如undefined、null、boolean、number、string、symbol)时,直接赋值无法改变原数组,因为它们的栈地址即为值本身。而当数组元素为对象、数组或函数时,由于这些是引用类型,forEach内部的赋值操作会影响到原始对象。总结了这一现象并解释了其背后的内存原理。

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

不知道你有没有遇到过这种情况

使用forEach的时候有时候能赋值上去,有时候又不得行!

比如说 赋值不行的时候:

        const arr = [1, true, '3', undefined, null, Symbol(6), 7, 8, 9]
        arr.forEach(item => {
            item = 'px'
        })
        console.log(arr) // [1, 2, 3, 4, 5, 6, 7, 8, 9]

赋值又可以的时候

		const arr = [
            { name: 'zk', list: [1, 2, 3], fn: (a, b) => a + b },
            { name: 'lz', list: [1, 2, 3], fn: (a, b) => a + b },
            { name: 'lh', list: [1, 2, 3], fn: (a, b) => a + b },
        ]
        arr.forEach(item => {
            item.name = 'px'
            item.list[0] = 'px'
            item.fn = (a, b) => a * b
        })
        console.log(arr) // [{name:"px", list:["px",2,3]}, fn: (a, b) => a * b} ....]

从以上结论来看,如果你对 堆栈 这方面有了解的话,那就不难而得之了;

  1. 如果给定的数组里面各项为 js基本类型(undefined、null、boolean、number、string、symbol) 的数据 ,此时赋值原数组里各项是不会发生改变的,因为他们的栈地址的值就是他们本身,此时修改,则无效,因为它并不是一个指向,此时如果要修改只能arr[i] 的方式去修改,arr[i]它代表着一个明确的堆地址。
  2. 如果给定的数组里面各项为 对象、数组、函数。此时赋值的原数组各项会发生改变,因为此时数组各项被存储的(栈)不是他们数据本身而是一个地址、堆的地址(这句话简而言之就是 在数组各项里面存储的是指向各自的堆地址)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值