理解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++中的指针传递,不过我们看不见这个指针。

相关推荐
崔庆才丨静觅17 分钟前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment20 分钟前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅35 分钟前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊37 分钟前
jwt介绍
前端
爱敲代码的小鱼44 分钟前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax
Cobyte1 小时前
AI全栈实战:使用 Python+LangChain+Vue3 构建一个 LLM 聊天应用
前端·后端·aigc
NEXT061 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
剪刀石头布啊1 小时前
生成随机数,Math.random的使用
前端
剪刀石头布啊1 小时前
css外边距重叠问题
前端
剪刀石头布啊1 小时前
chrome单页签内存分配上限问题,怎么解决
前端