基本类型参数传递时复制值,函数内修改不影响外部;对象类型传递引用地址,修改属性会影响外部对象,但重新赋值参数不影响原引用。

JavaScript 中的值传递和引用传递主要区别在于函数参数在传递时的行为方式,这取决于参数的数据类型。
基本类型是值传递
JavaScript 的基本类型(如 number、string、boolean、null、undefined、symbol)在作为参数传入函数时,是按值传递的。这意味着函数内部接收到的是原始值的一个副本,对参数的修改不会影响外部变量。
例如:
let a = 10;
function changeValue(num) {
num = 20;
}
changeValue(a);
console.log(a); // 输出 10
这里 num 是 a 的副本,函数内对 num 的修改不影响 a。
对象类型是引用传递
对象类型(包括数组、普通对象、函数等)在传参时是按引用传递的。函数接收到的是该对象在堆内存中的引用地址。因此,如果在函数内部修改了对象的内容,外部的对象也会受到影响。
例如:
let obj = { name: "Tom" };
function changeObj(o) {
o.name = "Jerry";
}
changeObj(obj);
console.log(obj.name); // 输出 "Jerry"
因为 o 和 obj 指向同一个对象,所以修改生效。
Magento是一套专业开源的PHP电子商务系统。Magento设计得非常灵活,具有模块化架构体系和丰富的功能。易于与第三方应用系统无缝集成。Magento开源网店系统的特点主要分以下几大类,网站管理促销和工具国际化支持SEO搜索引擎优化结账方式运输快递支付方式客户服务用户帐户目录管理目录浏览产品展示分析和报表Magento 1.6 主要包含以下新特性:•持久性购物 - 为不同的
但要注意:如果在函数内重新赋值整个参数引用,就不会影响外部对象。
let obj = { name: "Tom" };
function reassignObj(o) {
o = { name: "Bob" };
}
reassignObj(obj);
console.log(obj.name); // 仍输出 "Tom"
此时 o 被重新指向一个新对象,原 obj 不受影响。
基本上就这些。理解清楚数据类型和赋值行为,就能掌握 JS 中参数传递的本质。不复杂但容易忽略细节。









