js中的函数是按值传递还是按引用传递

文章目录


前置知识

如果关于js中普通类型和引用类型这两种类型的变量在赋值时存在的不同的同学,可以看看下面链接给出的博客。

js中关于普通类型的赋值和引用类型的赋值


结论

js中的函数是按值传递的,不是按引用传递。

原因解析

函数参数传递------基本类型

首先给大家看一段js代码:

js 复制代码
function f(n) {
  n = 2;
  console.log(n);//2
}
var num = 1;
console.log(num);//1
f(num);
console.log(num);//1

在将外部的基本类型变量num传入函数之后,就算对函数内的命名参数(局部变量)的数值修改,外部的变量num的数值并未变化(之前是1,函数内局部变量修改成2,外部的它还是1)

如果是按引用传递,外部变量num自然会受到函数赋值的影响,变成2。

函数参数传递------引用类型

js 复制代码
function f(obj) {
  obj.num = 2;
  console.log(obj);//2
}
var obj = {num:1};
console.log(obj);//{num: 1}
f(obj);
console.log(obj);//{num: 2}

从这里可以看到,函数内部对对象属性值的修改影响到了外部的对应对象。有些人其实是按照这个来认为函数参数的传递是按引用传递的,但这其实是错的,它其实还是值的传递

为了说明方便,将上文的函数参数名称改为:obj_

如果是按照函数参数按照引用传递,那么上述代码的关系应该是这样的:

那么真的是这样的吗,如果是这样,我对将一个新的对象赋值给obj_ ,obj对应的对象也应该发生改变。

执行代码如下(如有怀疑可以自行打开控制台验证):

js 复制代码
function f(obj_) {
  obj_.num = 2;
  console.log(obj_);//2
  obj_ = { num: 23333 }
  console.log(obj_);//{num: 23333}
}
var obj = { num: 1 };
console.log(obj);//{num: 1}
f(obj);
console.log(obj);//{num: 2}

执行结果:

结果很显而易见,将新的对象赋值给函数内部的变量,这一结果并没有让变量obj的数值改变。

它们的关系应该是这样的:

外部的obj将其保存的对象地址的引用,函数参数同样保存这一对象地址的引用,二者指向了同一个对象。上文的代码结果,是按值传递应该产生的结果。


至此,结束。

如果你觉得这篇文章写的不错,多多点赞~收藏吧!

相关推荐
资深web全栈开发1 小时前
[特殊字符]图解 Golang 反射机制:从底层原理看动态类型的秘密
开发语言·后端·golang
顾安r5 小时前
11.8 脚本网页 星际逃生
c语言·前端·javascript·flask
Hello.Reader5 小时前
Data Sink定义、参数与可落地示例
java·前端·网络
im_AMBER5 小时前
React 17
前端·javascript·笔记·学习·react.js·前端框架
一雨方知深秋5 小时前
2.fs模块对计算机硬盘进行读写操作(Promise进行封装)
javascript·node.js·promise·v8·cpython
独隅6 小时前
在 Lua 中,你可以使用 `os.date()` 函数轻松地将时间戳转换为格式化的时间字符串
开发语言·lua
谷歌开发者6 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (六)
前端·chrome·学习
一晌小贪欢6 小时前
【Html模板】电商运营可视化大屏模板 Excel存储 + 一键导出(已上线-可预览)
前端·数据分析·html·excel·数据看板·电商大屏·大屏看板
发现你走远了6 小时前
连接模拟器网页进行h5的调试(使用Chrome远程调试(推荐)) 保姆级图文
前端·chrome
思麟呀7 小时前
Linux的基础IO流
linux·运维·服务器·开发语言·c++