一直认为javascript函数的参数是普通的传值,对象的传址.
今天想把一个对象传到函数里面去重新生成后传出来,才知道我还是有地方理解错了.
先看的一段代码:
<html>
<body>
<script>
/*函數宣告
*********************/
function FuncA(num,bool){//測試數值和布林
num++;
bool=false;
document.write("在函數FuncA中的變數num值為:"+num+";變數bool值為"+bool+"<br/>");
}
function FuncB(str,man){//測試字串和物件
str="骷髏紳士";
man.name="劍俠鼻唄";
document.write("呼叫FuncB時:"+str+";"+man.name+"<br/>");
}
/*測試
*********************/
var num=1; //數值
var bool=true; //布林
var str="布魯克"; //字串
var man=new Object(); //物件
man.name="布魯克";
document.write("呼叫FuncA前,變數num的值為:"+num+"。變數bool的值為
:"+bool+"<br/>");
FuncA(num,bool);
document.write("呼叫FuncA後,變數num的值為:"+num+"。變數bool的值為
:"+bool+"<br/>");
document.write("呼叫FuncB前:"+str+"。"+man.name+"<br/>");
FuncB(str,man);
document.write("呼叫FuncB後:"+str+"。"+man.name+"<br/>");
</script>
</body>
</html>
运行结果没问题,与我想象的一样:
呼叫FuncA前,變數num的值為:1。變數bool的值為:true
在函數FuncA中的變數num值為:2;變數bool值為false
呼叫FuncA後,變數num的值為:1。變數bool的值為:true
呼叫FuncB前:布魯克。布魯克
呼叫FuncB時:骷髏紳士;劍俠鼻唄
呼叫FuncB後:布魯克。劍俠鼻唄
但,如果在FuncB中加一句
str="骷髏紳士";
man=new Object();
man.name="劍俠鼻唄";
结果:
呼叫FuncB前:布魯克。布魯克
呼叫FuncB時:骷髏紳士;劍俠鼻唄
呼叫FuncB後:布魯克。布魯克
新的man对象并没有返回来.
所以,我现在要这样理解,javascript都是拷贝值的,只是对象拷贝的是对象的地址,所以通过地址引用,可以修改其中的属性.但如果在程序内部更改了这个地址,它是不会传回来的.
不再折腾了,要想修改东西,还是用return来实现.