javascript 函数传参

通过值传递参数

在函数中调用的参数是函数的隐式参数。

JavaScript 隐式参数通过值来传递:函数仅仅只是获取值。

如果函数修改参数的值,不会修改显式参数的初始值(在函数外定义)。

隐式参数的改变在函数外是不可见的。

通过对象传递参数

在JavaScript中,可以引用对象的值。

因此我们在函数内部修改对象的属性就会修改其初始的值。

修改对象属性可作用于函数外部(全局变量)。

修改对象属性在函数外是可见的。

const backtrack=(i,path,j)=>{
    if(i==3) return
    if(i==1) {
        path.push('a')
        j=1
    }
    if(i==2) {
        path.pop()
        j=2
    }
    console.log('i='+i+' path='+path+' j='+j)
    backtrack(i+1,path,j)
    console.log('i='+i+' path='+path+' j='+j)
}
backtrack(0,[],0)

在这结果里插入图片描述

解释

当i=1时,隐式参数 j=1 ,即使进入更深层递归(i=2)中修改 j 值依然不改变 i=1 层的 j 值
当i=1时,显示参数 path=a(path为对象),进入更深层递归(i=2)中修改path的指向,会导致i=1层 path的指向发生变化。backtrack(0,[],0)中传入的[]为对象。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值