JS技术

javascript参数传址与传值_javascript教程教程

字号+ 作者:H5之家 来源:H5之家 2015-10-04 11:00 我要评论( )

javascript参数传址与传值,学习javascript参数传址与传值,javascript参数传址与传值,查看javascript参数传址与传值,一直认为javascript函数的参数是普通的传值,

一直认为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来实现.

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • JavaScript入门教程(二)_javascript教程教程

    JavaScript入门教程(二)_javascript教程教程

    2015-10-10 14:25

  • JavaScript入门教程(五)_javascript教程教程

    JavaScript入门教程(五)_javascript教程教程

    2015-10-10 14:21

  • JavaScript入门教程(四)_javascript教程教程

    JavaScript入门教程(四)_javascript教程教程

    2015-10-10 14:19

  • JavaScript入门教程(三)_javascript教程教程

    JavaScript入门教程(三)_javascript教程教程

    2015-10-10 14:17

网友点评