js 参数传递方式:按值传递

访问变量有按值和按引用两种方式,
基础数据类型按值访问,引用数据类型按引用(即指针或地址)访问。
但参数只能按值传递,
在向参数传递基本类型的值时,被传递的值会被复制给命名参数,引用类型时,传递的是它指针内存储的值
借用网上的一个例子

function setName(obj){  
  obj.name="nick";  
  console.log('第一次'+obj);
  obj=new Object(); // 类似于obj = 2;  
  // 此处实例化一个新的对象或将obj = 2,即切断了它与原先地址的联系,拥有一个新的指针,这个对象为局部变量
  // 只是这个obj和person的指针的值是一样的,但是两者是两个对象,对obj的操作并不会影响到person
  console.log('第二次'+obj);
  // 给这个新的对象添加属性
  obj.name="greg";  
    console.log('第三次'+obj);
}  

var person=new Object();  
setName(person);  
console.log('第四次'+person.name);  
第一次nick
第二次undefined
第三次greg
第四次nick

由此可以证明是按值传递,若是按引用传递,则第三次和第四次应该结果一样,
一段时间过后,再次来看这个,发现写的有些问题:
例如:

var person = {
    name:'tom',
    sex:'max'
};
function changeName(obj){
// 此处并没有创建新的对象,即没有切断obj和person 的联系,即我们操作的就是原始的person的指针的值
    obj.name = 'casy';
    console.log(obj);
}
changeName(person);
// 打印出来的是{name: "casy", sex: "max"}
console.log(person);
// 此时打印出来的{name: "casy", sex: "max"}
因为操作的是同一个对象,所以两次打印的值一致
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值