JavaScript函数参数完全指南:从基础到高级技巧,一网打尽!

一、函数参数的基本使用

1.1 基本参数传递

javascript 复制代码
// 基本参数
function greet(name, message) {
    return `${name}, ${message}!`;
}

console.log(greet("Alice", "Good morning"));
// "Alice, Good morning!"

1.2 默认参数(ES6+)

javascript 复制代码
// 默认参数值
function createUser(name, role = "user", isActive = true) {
    return { name, role, isActive };
}

console.log(createUser("Bob"));
// { name: 'Bob', role: 'user', isActive: true }
console.log(createUser("Carol", "admin"));
// { name: 'Carol', role: 'admin', isActive: true }
console.log(createUser("Eve", "user", false));
// { name: 'Eve', role: 'user', isActive: false }

1.3 剩余参数(Rest Parameters)

javascript 复制代码
// 收集所有剩余参数
function sum(prefix, ...numbers) {
    const total = numbers.reduce((acc, val) => acc + val, 0);
    return `${prefix}: ${total}`;
}

console.log(sum("结果", 1, 2, 3, 4)); // "结果: 10"

1.4 函数自带的arguments关键字

javascript 复制代码
function sum() {
    let total = 0;
    for (let i = 0; i < arguments.length; i++) {
        total += arguments[i];
    }
    console.log("结果:", total);  // "结果: 10"
}

sum(1, 2, 3, 4);

二、参数处理技巧

2.1 使用对象解构处理多个参数:提高可读性和可维护性

javascript 复制代码
// 对象参数解构
function displayUser({ name, age, email = "N/A" }) {
    console.log(`名称: ${name}`);
    console.log(`年龄: ${age}`);
    console.log(`邮箱: ${email}`);
}

const user = { name: "Dave", age: 30 };
displayUser(user);
// 名称: Dave
// 年龄: 30
// 邮箱: N/A

// 数组参数解构
function getFirstAndLast([first, , , last]) {
    return { first, last };
}

const colors = ["red", "green", "blue", "yellow"];
console.log(getFirstAndLast(colors));
// { first: 'red', last: 'yellow' }

2.2 优先使用默认参数 :代替逻辑或(||)操作符

javascript 复制代码
// 推荐
function greet(name = '访客') {}

// 不推荐
function greet(name) {
  name = name || '访客';
}

2.3 合理使用rest参数:代替arguments对象

javascript 复制代码
// 推荐 (ES6+)
function sum(...numbers) {}

// 不推荐 (ES5)
function sum() {
  var numbers = Array.prototype.slice.call(arguments);
}

总结

如果你喜欢本教程,记得点赞+收藏!关注我获取更多JavaScript开发干货。

相关推荐
丫丫7237344 分钟前
Three.js 模型树结构与节点查询学习笔记
javascript·webgl
车传新24 分钟前
Javascript
javascript
天若有情67341 分钟前
【c++】手撸C++ Promise:从零实现通用异步回调组件,支持链式调用+异常安全
开发语言·前端·javascript·c++·promise
抱琴_1 小时前
【Vue3】大屏性能优化黑科技:Vue 3 中实现请求合并,让你的大屏飞起来!
前端·vue.js
不会玩电脑的Xin.1 小时前
HTML + CSS
前端·css·html
hadage2331 小时前
--- JavaScript 的一些常用语法总结 ---
java·前端·javascript
彭于晏爱编程1 小时前
🍭🍭🍭升级 AntD 6:做第一个吃螃蟹的人
前端
掘金一周2 小时前
大部分人都错了!这才是chrome插件多脚本通信的正确姿势 | 掘金一周 11.27
前端·人工智能·后端
jason_yang2 小时前
vue3中createApp多个实例共享状态
javascript·vue.js