JavaScript函数参数按值传递,原始类型传值副本,引用类型传引用副本;修改引用类型属性影响外部,但重新赋值参数不影响。

JavaScript函数的参数传递方式主要依赖于参数的类型,理解这一点对编写可靠代码非常重要。函数调用时,参数的传递看似统一,但实际行为会因传入的是原始类型还是引用类型而不同。
JavaScript中所有函数参数都是按值传递的,但这个“值”的含义在不同类型间有所不同:
原始类型在函数中被当作独立的副本处理:
例如:
立即学习“Java免费学习笔记(深入)”;
function changeValue(num) {
num = 100;
console.log(num); // 输出 100
}
let a = 5;
changeValue(a);
console.log(a); // 输出 5,原变量未受影响
这里 num 是 a 的值的拷贝,函数内的修改不影响外部。
引用类型传递的是地址副本,因此可以操作原对象:
例如:
立即学习“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。
function greet(name = "游客") { ... }
以上就是JS函数参数怎么传递_JavaScript函数参数传递方式与注意事项的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号