JavaScript 传参方法

1. 值传递

在 JavaScript 中,基本类型(也称为原始类型)包括 undefinednullbooleannumberstringbigintsymbol。这些类型在函数调用时是通过值传递的,这意味着在函数内部修改参数的值不会影响函数外部的原始值。

javascript 复制代码
function modifyValue(value) {
    value = 10;
}

let num = 5;
modifyValue(num);
console.log(num); // 输出:5
  1. 引用传递

与基本类型不同,引用类型(如对象和数组)在传递时是通过引用传递的。这意味着在函数内部修改参数会影响到函数外部的对象或数组。

javascript 复制代码
function modifyObject(obj) {
    obj.name = "Alice";
}

let person = { name: "Bob" };
modifyObject(person);
console.log(person.name); // 输出:Alice
3. 数组解构

通过数组解构,我们可以直接将数组元素分配给函数参数。

javascript 复制代码
function sum([a, b, c]) {
    return a + b + c;
}

let numbers = [1, 2, 3];
console.log(sum(numbers)); // 输出:6
4. 对象解构

对象解构允许我们提取对象中的特定属性,并将其赋值给对应的函数参数。

javascript 复制代码
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.
  1. Rest 参数

Rest 参数语法允许我们将不确定数量的参数表示为数组。这在处理可变参数函数时非常有用。

javascript 复制代码
function sum(...numbers) {
    return numbers.reduce((acc, num) => acc + num, 0);
}

console.log(sum(1, 2, 3, 4)); // 输出:10

6.默认参数

默认参数允许我们在函数定义时为参数设置默认值,如果在函数调用时未传递该参数,则使用默认值。

javascript 复制代码
function greet(name = "Guest") {
    return `Hello, ${name}!`;
}

console.log(greet()); // 输出:Hello, Guest!
console.log(greet("Alice")); // 输出:Hello, Alice!
相关推荐
社恐的下水道蟑螂13 分钟前
从字符串到像素:深度解析 HTML/CSS/JS 的页面渲染全过程
javascript·css·html
程序定小飞14 分钟前
基于springboot的web的音乐网站开发与设计
java·前端·数据库·vue.js·spring boot·后端·spring
Hello_WOAIAI16 分钟前
2.4 python装饰器在 Web 框架和测试中的实战应用
开发语言·前端·python
搬山.摧城22 分钟前
线程池和单例模式
开发语言·单例模式
百锦再26 分钟前
第1章 Rust语言概述
java·开发语言·人工智能·python·rust·go·1024程序员节
武昌库里写JAVA30 分钟前
element-ui 2.x 及 vxe-table 2.x 使用 css 定制主题
java·vue.js·spring boot·sql·学习
一叶之秋141236 分钟前
QT背景介绍与环境搭建
开发语言·qt
java1234_小锋1 小时前
PyTorch2 Python深度学习 - 模型保存与加载
开发语言·python·深度学习·pytorch2
JavaGuide1 小时前
OPPO 后端校招面试,过于简单了!
java·后端
行走的陀螺仪1 小时前
uni-app + Vue3 实现折叠文本(超出省略 + 展开收起)
前端·javascript·css·uni-app·vue3