Javascript函数传参(按值传参不是传引用)

变量传参的问题,里边有这么一个例子,一直无法理解,为什么函数内部的obj没有重写原来的obj?

                function setName(obj) {
                    obj.name = "Nicholas";
                    obj = new Object();
                    obj.name = "Greg";
                }
                var person = new Object();
                setName(person);
                alert(person.name);//"Nicholas"

2

JavaScript中的传参无论什么类型都是按值传递的,这对于基本类型的传参是很好理解的,但是对于引用类型的传参就不太好理解,这是JavaScript的语法规则。 下面说一下这个例子:

function setName(obj) {
    obj.name = "Nicholas";
    obj = new Object();
    obj.name = "Greg";
}
var person = new Object();
setName(person);
alert(person.name);//"Nicholas"

下面来分析一下:

  1. var person = new Object(); 创建person实例。

  2. setName(person) 这里把这个实例按值传递给setName这个函数,所谓按值传递,就是把person拷贝一份副本,然后传入这个函数,因为person是引用类型,所以它和它的副本都有一个指针指向内存的同一块区域。

  3. obj.name = "Nicholas"; 副本把内存里面的值改为"Nicholas",此时person.name的值也就变为"Nicholas",因为他们指向同一块内存。

  4. obj = new Object();obj.name = "Greg"; 通过new一个新的实例,并赋值给obj(之前是person按值传递的副本),我们把obj的指针指向了新的内存区域,并赋值为"Greg",此时obj和person因为不是指向同一块内存区域,所以person.name还是原来的Nicholas。

如果还不理解,请认真理解下面的例子:

var person = new Object();
person.name = "Tabweng";

var anotherPerson = person;

console.log(anotherPerson.name); //TabWeng

person.name = "Weng";

console.log(anotherPerson.name); //Weng

person = new Object();

person.name = "Tab";

console.log(anotherPerson.name); //Weng 
我自己又写的测试例子:
//按值传参跟基本类型复制赋值是一个道理,将变量的值拷贝一个副本赋给另一个变量二者是独立的互不影响
// var o ="sb";
// function test(o){//相当于基本变量复制赋值,不会改变外部o的值,
// 					//如果是引用变量赋值,引用的是同一个对象会改变值
// 	o="gd";
// }
// test(o);
// alert(o);//弹出sb
// function setName(o){
// 	//调用此函数的时候将对象赋值给局部变量o
// 	//也就是将对象的副本赋给o,此时o和外部传入的
// 	//对象指针都是指向同一个对象
// 	o.name="mab";
// }
// var person = new Object();
// setName(person);
// alert(person.name);


function setName(o){
	//调用此函数的时候将对象赋值给局部变量o
	//也就是将对象的副本赋给o,此时o和外部传入的
	//对象指针都是指向同一个对象
	o.name="mab";
	o = {name:"sb"};
	//相当于重新new了一个对象赋给o此时生成的新对象将引用赋给o,
 //这样o跟外部对象就是指向两个不同的引用
   alert(o.name);
}
var person = new Object();
setName(person);
alert(person.name);

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值