理解前端函数

📜 JS 基础函数🔢 高阶函数💚 Vue 3 函数📊 总结对比

📜

函数的三种写法

函数声明 · 函数表达式 · 箭头函数

写法 语法 核心特点
函数声明 function fn() {} 有提升,可在声明前调用
函数表达式 const fn = function() {} 无提升,必须先声明再使用
箭头函数 const fn = () => {} 更简洁,无自己的 this(最常用)

JavaScript

复制

复制代码
// ① 函数声明(有变量提升)
function greet(name) {
  return "你好," + name
}
greet("前端")   // → "你好,前端"

// ② 函数表达式
const greet = function(name) {
  return `你好,${name}`
}

// ③ 箭头函数(Vue 3 最常用)
const greet = (name) => `你好,${name}`

// 只有一个参数时,括号可省略
const double = n => n * 2

💡

Vue 3 开发建议<script setup> 中推荐全部使用箭头函数,代码更简洁,也不会有 this 指向问题。

🎯

函数参数特性

默认参数 · 剩余参数 · 解构参数

JavaScript

复制

复制代码
// ① 默认参数:调用时未传则使用默认值
const add = (a, b = 0) => a + b
add(5)          // → 5(b 默认为 0)
add(5, 3)       // → 8

// ② 剩余参数:收集多余参数到数组
const sum = (...nums) => nums.reduce((a, b) => a + b, 0)
sum(1, 2, 3, 4)  // → 10

// ③ 解构参数:直接取对象中的字段
const show = ({ name, age }) => `${name} 今年 ${age} 岁`
show({ name: "博客", age: 20, grade: "大二" })
// → "博客 今年 20 岁"

⚠️

注意 剩余参数 ...nums 必须放在参数列表的最后一位,否则会报错。

相关推荐
2501_943782352 小时前
【共创季稿事节】猜数字游戏:二分法思维与交互式反馈
前端·游戏·microsoft·harmonyos·鸿蒙·鸿蒙系统
GV191rLvq2 小时前
基于Socket实现的最简单的Web服务器【ASP.NET原理分析】
服务器·前端·asp.net
吠品2 小时前
LangChain 里 tool_call_id 为空?一次 MCP 工具集成的排查记录
前端
柒和远方2 小时前
Phase 7.4 学习博客:为什么多 API 项目需要 Swagger / OpenAPI
前端·后端·架构
张龙6872 小时前
拼多多开放平台对接踩坑实录:从 CLIENT_ID 配置到 MD5 签名算法的完整填坑指南
前端
GuWenyue2 小时前
提示词彻底过时?一套上下文工程方案,3步让LLM落地生产,代码直接复用
前端·javascript·人工智能
柒和远方3 小时前
Phase 7.3 复盘:后台任务不只是“扔进队列”,还要能被看见
前端·后端·架构
2501_943782353 小时前
【共创季稿事节】 倒计时器:时分秒选择器与定时器的协同工作
前端·华为·harmonyos·鸿蒙·鸿蒙系统
奶油mm3 小时前
公司技术债堆积如山,我一人之力用 Vue3 偷换了整个前端架构
前端·vue.js