1. 值传递
在 JavaScript 中,基本类型(也称为原始类型)包括 undefined
、null
、boolean
、number
、string
、bigint
和 symbol
。这些类型在函数调用时是通过值传递的,这意味着在函数内部修改参数的值不会影响函数外部的原始值。
function modifyValue(value) { value = 10; } let num = 5; modifyValue(num); console.log(num); // 输出:5
2. 引用传递
与基本类型不同,引用类型(如对象和数组)在传递时是通过引用传递的。这意味着在函数内部修改参数会影响到函数外部的对象或数组。
function modifyObject(obj) { obj.name = "Alice"; } let person = { name: "Bob" }; modifyObject(person); console.log(person.name); // 输出:Alice
3. 数组解构
通过数组解构,我们可以直接将数组元素分配给函数参数。
function sum([a, b, c]) { return a + b + c; } let numbers = [1, 2, 3]; console.log(sum(numbers)); // 输出:6
4. 对象解构
对象解构允许我们提取对象中的特定属性,并将其赋值给对应的函数参数。
function greet({ name, age }) { return `Hello, my name is ${name} and I am ${age} years old.`; } let person = { name: "John", age: 30 }; console.log(greet(person)); // 输出:Hello, my name is John and I am 30 years old.
5. Rest 参数
Rest 参数语法允许我们将不确定数量的参数表示为数组。这在处理可变参数函数时非常有用。
function sum(...numbers) { return numbers.reduce((acc, num) => acc + num, 0); } console.log(sum(1, 2, 3, 4)); // 输出:10
6.默认参数
默认参数允许我们在函数定义时为参数设置默认值,如果在函数调用时未传递该参数,则使用默认值。
function greet(name = "Guest") { return `Hello, ${name}!`; } console.log(greet()); // 输出:Hello, Guest! console.log(greet("Alice")); // 输出:Hello, Alice!