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()中this是obj) - 箭头函数没有
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 中(该值只统计非剩余参数个数)。
为什么函数内部改了变量,外部没变
这通常是因为传入的是原始类型(string、number、boolean、undefined、null、symbol、bigint),它们按值传递;而对象、数组、函数等引用类型按“共享引用”传递——你改属性会影响外部,但直接赋值新对象不会。
let x = 5; function f(n) { n = 10; } f(x); console.log(x); // 还是 5let obj = { a: 1 }; function g(o) { o.a = 2; } g(obj); console.log(obj.a); // 2function 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响应的最佳实践
高防服务器租用如何选择配置与防御等级?

