JavaScript函数如何定义_它能实现什么功能

发布时间 - 2026-01-05 00:00:00    点击率:
JavaScript函数的核心差异在于this绑定、参数处理和调用方式:function声明具提升性、独立this和arguments,可作构造函数;箭头函数无this和arguments、不可构造、继承外层this;剩余参数替代arguments;原始类型传值,引用类型传共享引用;闭包需防内存泄漏。

JavaScript 函数不是“只能做一件事”的工具,而是可复用、可传递、可嵌套的代码单元——定义方式直接影响它能不能被正确调用、能不能访问外部变量、会不会意外修改全局状态。

function 声明和箭头函数的区别在哪

最常见却最容易混淆的是 function 声明与箭头函数(() => {})的行为差异。它们不只写法不同,关键在于 this 绑定、arguments 支持、以及是否能作为构造函数使用。

  • function 声明会被提升(hoisted),可在定义前调用;箭头函数不会,必须先声明再调用
  • 箭头函数没有自己的 this,它继承外层函数作用域的 this;普通函数的 this 取决于调用方式(如 obj.fn()thisobj
  • 箭头函数没有 arguments 对象,要用剩余参数 ...args 替代
  • new 不能用于箭头函数,会报错 TypeError: xxx is not a constructor

如何让函数接收不确定数量的参数

用剩余参数(...args)替代老旧的 arguments 对象,更安全、更符合数组操作习惯。

function sum(...numbers) {
  return numbers.reduce((a, b) => a + b, 0);
}
sum(1, 2, 3); // 6
sum(); // 0

注意:...args 必须是最后一个形参;不能和 arguments 混用;在严格模式下,它不会出现在 function.length 中(该值只统计非剩余参数个数)。

为什么函数内部改了变量,外部没变

这通常是因为传入的是原始类型(stringnumberbooleanundefinednullsymbolbigint),它们按值传递;而对象、数组、函数等引用类型按“共享引用”传递——你改属性会影响外部,但直接赋值新对象不会。

  • let x = 5; function f(n) { n = 10; } f(x); console.log(x); // 还是 5
  • let obj = { a: 1 }; function g(o) { o.a = 2; } g(obj); console.log(obj.a); // 2
  • function h(o) { o = { b: 3 }; } h(obj); console.log(obj.b); // undefined —— 因为 o 被重新赋值,断开了与原对象的联系

闭包常被滥用的两个场景

闭包本质是函数记住了它被定义时的作用域链。它有用,但容易引发内存泄漏或意料之外的变量共享。

  • 循环中创建定时器:用 let 声明循环变量,避免所有回调共享同一个 var i;或者用 IIFE 包裹(已过时,仅作理解)
  • 私有数据模拟:用闭包封装变量,但别把大对象长期挂在闭包里,尤其在事件监听器中未及时移除时

典型错误写法:for (var i = 0; i console.log(i), 100); 输出三个 3;正确应为 for (let i = 0; i 或 (function(i) { setTimeout(() => console.log(i), 100); })(i)

函数不是语法糖,它是 JavaScript 的一等公民——它的定义方式、调用时机、作用域边界,共同决定了逻辑是否可靠、调试是否清晰、性能是否可控。别只盯着怎么写,多问一句“它此刻绑定了谁的 this?捕获了哪些变量?会被 GC 回收吗?”


# javascript  # java  # 工具  # 区别  # 作用域  # 为什么  # red 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在建站之星绑定自定义域名?  如何用AWS免费套餐快速搭建高效网站?  创业网站制作流程,创业网站可靠吗?  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  如何基于云服务器快速搭建个人网站?  Laravel Docker环境搭建教程_Laravel Sail使用指南  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  大同网页,大同瑞慈医院官网?  Python文件异常处理策略_健壮性说明【指导】  在线教育网站制作平台,山西立德教育官网?  如何挑选优质建站一级代理提升网站排名?  在线制作视频网站免费,都有哪些好的动漫网站?  Laravel如何自定义分页视图?(Pagination示例)  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  Android Socket接口实现即时通讯实例代码  如何快速选择适合个人网站的云服务器配置?  ,在苏州找工作,上哪个网站比较好?  文字头像制作网站推荐软件,醒图能自动配文字吗?  EditPlus中的正则表达式 实战(4)  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  Laravel怎么使用artisan命令缓存配置和视图  微信推文制作网站有哪些,怎么做微信推文,急?  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  音乐网站服务器如何优化API响应速度?  Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  Internet Explorer官网直接进入 IE浏览器在线体验版网址  如何快速生成凡客建站的专业级图册?  Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案  Python进程池调度策略_任务分发说明【指导】  如何快速使用云服务器搭建个人网站?  如何在Windows服务器上快速搭建网站?  Laravel集合Collection怎么用_Laravel集合常用函数详解  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  IOS倒计时设置UIButton标题title的抖动问题  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南  如何在云主机上快速搭建多站点网站?  Laravel如何与Inertia.js和Vue/React构建现代单页应用  uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址  使用spring连接及操作mongodb3.0实例  Laravel怎么实现模型属性的自动加密  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  Android自定义listview布局实现上拉加载下拉刷新功能  Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践  高防服务器租用如何选择配置与防御等级?