首页 > web前端 > js教程 > 正文

JS函数参数怎么传递_JavaScript函数参数传递方式与注意事项

看不見的法師
发布: 2025-11-06 17:18:02
原创
258人浏览过
JavaScript函数参数按值传递,原始类型传值副本,引用类型传引用副本;修改引用类型属性影响外部,但重新赋值参数不影响。

js函数参数怎么传递_javascript函数参数传递方式与注意事项

JavaScript函数的参数传递方式主要依赖于参数的类型,理解这一点对编写可靠代码非常重要。函数调用时,参数的传递看似统一,但实际行为会因传入的是原始类型还是引用类型而不同。

按值传递与按引用传递的区别

JavaScript中所有函数参数都是按值传递的,但这个“值”的含义在不同类型间有所不同:

  • 对于原始类型(如 number、string、boolean、null、undefined、symbol),传递的是变量的实际值的副本。在函数内部修改参数不会影响外部变量。
  • 对于引用类型(如对象、数组、函数),传递的是该引用的副本,也就是指向同一对象的指针。因此函数内部可以通过这个引用来修改对象的属性,外部也会看到这些变化。
注意:即使引用类型传递的是引用的副本,重新赋值该参数并不会改变外部变量的指向。

原始类型的参数传递

原始类型在函数中被当作独立的副本处理:

例如:

立即学习Java免费学习笔记(深入)”;

function changeValue(num) {
  num = 100;
  console.log(num); // 输出 100
}
let a = 5;
changeValue(a);
console.log(a); // 输出 5,原变量未受影响
登录后复制

这里 numa 的值的拷贝,函数内的修改不影响外部。

阿里云-虚拟数字人
阿里云-虚拟数字人

阿里云-虚拟数字人是什么? ...

阿里云-虚拟数字人 2
查看详情 阿里云-虚拟数字人

引用类型的参数传递

引用类型传递的是地址副本,因此可以操作原对象:

例如:

立即学习Java免费学习笔记(深入)”;

function modifyObj(obj) {
  obj.name = "张三";
  console.log(obj.name); // 输出 "张三"
}
let person = { name: "李四" };
modifyObj(person);
console.log(person.name); // 输出 "张三",原对象被修改
登录后复制

虽然可以修改对象内容,但如果尝试重新赋值参数:

function reassignObj(obj) {
  obj = { name: "王五" };
  console.log(obj.name); // 输出 "王五"
}
let person = { name: "李四" };
reassignObj(person);
console.log(person.name); // 仍输出 "李四"
登录后复制

因为 obj 只是引用的副本,重新赋值只会改变局部变量的指向,不影响外部的 person

注意事项与最佳实践

  • 避免在函数内部意外修改传入的对象。如需安全操作,可使用 Object.assign({}, obj) 或展开语法 {...obj} 创建副本。
  • 对于数组,可用 slice()[...arr] 进行浅拷贝。
  • 如果需要深层克隆对象,考虑使用 JSON.parse(JSON.stringify(obj))(注意:不支持函数和循环引用)或第三方库如 Lodash 的 cloneDeep。
  • 合理使用默认参数,提高函数健壮性:
    function greet(name = "游客") { ... }
基本上就这些。掌握参数传递机制,能有效避免副作用,写出更清晰、可预测的函数。

以上就是JS函数参数怎么传递_JavaScript函数参数传递方式与注意事项的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号