理解JavaScript中的函数参数传递

《JavaScript高级程序设计》中写道:" ECMAScript 中所有函数的参数都是按值传递的。 "。

对于简单数据类型,这个说法很容易理解,传递给函数的参数实际上就是原始值的一个复制,在函数中修改参数值不会影响到原始值。如下面这段代码所示:

ini 复制代码
function addTen(num) { 
  num += 10;  
  return num; 
} 

let count = 20;
let result = addTen(count); 
console.log(count);  // 20,没有变化 
console.log(result); // 30 

对于引用数据类型,这个说法可能就会带来困惑了,我们先看下面这段代码:

ini 复制代码
function setName(obj) { 
  obj.name = "Nicholas";  
} 
let person = new Object(); 
setName(person); 
console.log(person.name);  // "Nicholas" 

看到上述代码的输出结果,我们可能会觉得奇怪,既然是值传递而不是引用传递,对函数内部变量的修改又为什么会反映到函数外部呢?这样的表现似乎更符合引用传递的预期,即函数可以直接修改变量原始值。我们接下来再看这样的一段代码:

ini 复制代码
function setName(obj) { 
  obj.name = "Nicholas";  
  obj = new Object(); 
  obj.name = "Greg"; 
} 
let person = new Object(); 
setName(person); 
console.log(person.name);  // "Nicholas" 

看到上面这段代码的输出结果,我们就可以来讨论为什么说JavaScript的函数参数传递都是值传递了。

对于简单数据类型,"值传递"传递的就是变量值;而对于引用数据类型,可以认为"值传递"传递的是变量的内存地址值,也就是说创建了一个引用类型的变量的地址的副本 ,函数内外的变量指向同一个对象,这时在函数内部修改对象值,外部变量值自然也会改变。但是如果在函数内部对变量重新赋值,相当于把内部变量的值指向了一个新的地址,这时再修改内部对象值,自然不会影响到外部变量值。

这两种情况大致如下图所示:

总之,对于引用数据类型的函数参数传递,我觉得可以类比为C++中的指针传递,不过我们看不见这个指针。

相关推荐
该怎么办呢5 分钟前
Source/Core/DeveloperError.js
开发语言·javascript·ecmascript
于慨26 分钟前
tauri
java·服务器·前端
贼爱学习的小黄1 小时前
NC BIP参照开发
java·前端·nc
weixin_462901971 小时前
ESP32 LED控制代码解析
javascript
小江的记录本1 小时前
【MyBatis-Plus】MyBatis-Plus的核心特性、条件构造器、分页插件、乐观锁插件
java·前端·spring boot·后端·sql·tomcat·mybatis
小张会进步1 小时前
数组:二维数组
java·javascript·算法
光影少年1 小时前
如何进行前端性能优化?
前端·性能优化
Dxy12393102161 小时前
js如何把字符串转数字
开发语言·前端·javascript
爱写bug的野原新之助1 小时前
爬虫之补环境:加载原型链
前端·javascript·爬虫
陈广亮2 小时前
工具指南7-Unix时间戳转换工具
前端