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

相关推荐
昵称暂无19 分钟前
.NET 高级开发 | i18n 原理、实现一个 i18n 框架
javascript·c#·.net
西西小飞龙10 分钟前
Less/Sass Mixins vs. Extend
前端·less·sass
syjy213 分钟前
(含下载)BeTheme WordPress主题使用教程
前端·wordpress·wordpress建站
Misnice21 分钟前
shadcn如何使用
前端·reactjs
h_jQuery25 分钟前
vue使用gm-crypto对数据进行sm4加密处理
前端·javascript·vue.js
阿赛工作室1 小时前
Vue中onBeforeUnmount不触发的解决方案
前端·javascript·vue.js
码王吴彦祖1 小时前
顶象 AC 纯算法迁移实战:从补环境到纯算的完整拆解
java·前端·算法
小叶lr1 小时前
jenkins打包前端样式丢失/与本地不一致问题
运维·前端·jenkins
浩星1 小时前
electron系列1:Electron不是玩具,为什么桌面应用需要它?
前端·javascript·electron
ZC跨境爬虫2 小时前
Scrapy工作空间搭建与目录结构解析:从初始化到基础配置全流程
前端·爬虫·python·scrapy·自动化