Js函数参数, 传递的是值还是地址? 都是传值!!!

红宝书中是这样说的

在这里插入图片描述

  • 基本数据类型传递的是值
/**
 * 全局作用域、函数变量、函数内部作用域
 *
 */

let a = 10
let b = 1

function sum(a, b){
    a = 11
    b = 2
    console.log(a) // 11
    console.log(b) // 2

}

console.log(a) // 10
console.log(b) // 1

// 记住, 普通数据类型传递的是参数的值,不是参数的地址,所以,不会修改参数真正的数据
sum(a, b)
console.log(a); // 10
console.log(b); // 1

  • 引用数据类型传递的也是值, 不过这个值是一个地址指针
/**
 * 引用数据类型和参数传递的是值还是指针
 */

// 引用数据类型作为参数, 传递的还是值, 但是这个值是引用数据类型的第一个地址。

const objCK = {name: 'ck'}

function setName(obj) {
    obj.name = 'kb'
    // 将obj引用指针指向了新的一个对象上
    obj = new Object()
    obj.name = 'new'
}

console.log(objCK.name) // ck
setName(objCK)
// 如果这里是按照引用传递,那么,下面的输出应该是new
console.log(objCK.name) // kb


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值