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

相关推荐
不说别的就是很菜6 分钟前
【前端面试】CSS篇
前端·css·面试
by__csdn29 分钟前
nvm安装部分node版本后没有npm的问题(14及以下版本)
前端·npm·node.js
by__csdn34 分钟前
Node与Npm国内最新镜像配置(淘宝镜像/清华大学镜像)
前端·npm·node.js
脸大是真的好~1 小时前
黑马JAVAWeb -Vue工程化-API风格 - 组合式API
前端·javascript·vue.js
我命由我123451 小时前
CesiumJS 案例 P35:添加图片图层(添加图片数据)
开发语言·前端·javascript·css·html·html5·js
你挚爱的强哥1 小时前
【sgMobileUploadTypeSelect】自定义组件:从底部弹出选择上传图片文件的方式【1、上传本地文件,2、拍摄上传】
前端·javascript·vue.js
Mike_jia1 小时前
Checkmate:自建监控新标杆!开源替代Zabbix的轻量级方案实战
前端
fury_1231 小时前
tsfile.raw提示
java·前端·javascript
喝拿铁写前端1 小时前
从面条代码到抽象能力:一个小表单场景里的前端成长四阶段
前端·设计模式·架构
LXA08092 小时前
Vue 3中使用JSX
前端·javascript·vue.js