WEB开发网
开发学院网页设计JavaScript Javascript中函数传引用被覆盖问题 阅读

Javascript中函数传引用被覆盖问题

 2009-02-13 20:06:07 来源:WEB开发网   
核心提示:在javascript中我们知道给一个函数传递一个数组做为实参,这是按引用传递的,Javascript中函数传引用被覆盖问题,但如果在这个函数里面覆盖这个引用,那么会有什么结果呢?请看下面的代码:+ 展开代码查看源码打印?·········10········20········30········40········

在javascript中我们知道给一个函数传递一个数组做为实参,这是按引用传递的,但如果在这个函数里面覆盖这个引用,那么会有什么结果呢?请看下面的代码:


+ 展开代码查看源码打印?·········10········20········30········40········50········60········70········80········90········100·······110·······120·······130·······140·······150
01.var oldArray = [1, 2, 3];
02.
 
03.function modifyArray1(oldArray) {
04.  
oldArray[0] = 'test1'; //改变数组的某个元素是可以的
05.  
PRint(oldArray + ' in modifyArray1');
06.}
07.
 
08.modifyArray1(oldArray);
09.print(oldArray + ' out modifyArray1');
10.
 
11.print('==========================================');
12.
 
13.oldArray = [1, 2, 3]; //复原数组
14.
 
15.function modifyArray2(oldArray) {
16.  
var newArray = ['a', 'b', 'c'];
17.  
oldArray[0] = 'test2'; //对数组元素的更改是有效的
18.  
oldArray = newArray; //覆盖引用,一旦出了函数的作用域就是无效的
19.  
print(oldArray + ' in modifyArray2');
20.}
21.
 
22.modifyArray2(oldArray);
23.print(oldArray + ' out modifyArray2');
可以通过Javascript shell来执行这段代码。我的输出结果为:

+ 展开代码查看源码打印?·········10········20········30········40········50········60········70········80········90········100·······110·······120·······130·······140·······150
1.test1,2,3 in modifyArray1
2.test1,2,3 out modifyArray1
3.==========================================
4.a,b,c in modifyArray2
5.test2,2,3 out modifyArray2
这就说明了一个事实:在一个函数里如果直接覆盖实际参数的引用,在函数内部是有效的,但出了函数作用域就会失效。

Tags:Javascript 函数 引用

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接