当前位置: 首页 > news >正文

js函数声明和函数表达式的理解

什么是函数声明

以 function 关键字开头,必须指定函数名(如 function greet() {}),且不能作为其他语句的一部分。‌‌

函数声明会被提升

在JS中,函数声明会被提升,这意味着函数可以在声明之前被调用。
当你使用函数声明的方式定义函数: function resizeFn() {...}
整个函数声明会被提升到作用域的顶部。
这意味着在整个作用域内,无论函数在何处声明,都可以在声明前调用。

函数声明会被提升的代码解释

// 因为是函数声明,所以可以在函数声明之前调用。可以正常调用
resizeFn(); // 因为这是一个函数声明。
function resizeFn() {// 函数体
}

函数表达式

‌函数表达式‌:将函数赋值给变量,函数可匿名或具名
如 const sayHello = function() {}
或 const sayHello = function named() {}
函数表达式适用于赋值、参数传递等场景。‌‌
函数表达式‌:仅变量名被提升,函数体不会提升。
函数表达式:必须先定义后使用(也就是说在使用[调用]前,必须先定义)

函数表达式:必须先定义后使用

sayHello()
const sayHello = function() {} 

image
报错:Uncaught ReferenceError: Cannot access 'sayHello' before initialization

总结:看了上面的函数声明和函数表达式,也许你对函数声明和函数表达式有一定的理解了。
我们来看下面这个,函数表达式一定必须是:先定义后使用嘛?

函数表达式一定是先定义后使用嘛?

mounted () {this.myChart = echarts.init(this.$refs.chartContainer)const chartContainerElement = this.$refs.chartContainerconst resizeObserver = new ResizeObserver(() => {// 先使用了resizeFn()})// 后定义了const resizeFn = this._.debounce(() => {this.myChart && this.myChart.resize()}, 500)chartContainerElement && resizeObserver.observe(chartContainerElement)this.$once('hook:beforeDestroy', () => {resizeObserver.disconnect()})
}

我们的函数表达式 const resizeFn。
目前是:先使用后定义,那么在运行的时候会报错吗?
答案是:不会的。
因为:这里有一个重要的执行时机差。实际上在调用前,已经被定义了。
我们被代码的先后顺序给误导了。
并不是说:定义函数表达式的代码必须要写在函数调用之前。

  1. 异步执行时机
const resizeObserver = new ResizeObserver(() => {resizeFn()  // 这里不会立即执行!
})

关键点:ResizeObserver 的回调函数不是立即执行的,而是在元素尺寸变化时异步触发的。

  1. 代码执行顺序
// 步骤1:定义 ResizeObserver的 回调(此时只是定义,不执行)
const resizeObserver = new ResizeObserver(() => {resizeFn()  // 此时 resizeFn 还未定义,但不会报错,因为函数没有立即调用
})// 步骤2:定义  resizeFn ( 在执行任何 resize 事件前已经定义完成)
const resizeFn = this._.debounce(() => {this.echart_alarm && this.echart_alarm.resize()
}, 500)// 步骤3:开始观察(此时 resizeFn 已经存在)
chartContainerElement && resizeObserver.observe(chartContainerElement)

时间线说明

时间点:
t0: 定义 ResizeObserver 回调函数
t1: 定义 resizeFn 函数表达式  
t2: 开始观察元素尺寸变化
t3: 用户操作导致元素尺寸变化(此时才真正调用 resizeFn)

尾声

如果你看了有收获,请给我点一个推荐
如果给我打赏了,那保证你未来大富大贵

http://www.jsqmd.com/news/20488/

相关文章:

  • 2025 天津电竞网吧最新推荐榜单权威发布:Z 世代电竞领衔五大实力品牌,技术与口碑深度解析!
  • 合成孔径雷达(SAR)成像仿真
  • 2025 年最新推荐智能门锁厂家榜单:涵盖高端 / 猫眼 / 家用 / 人脸 / 续航 / 掌静脉等多类型,帮消费者避开劣质产品选到靠谱品牌
  • 动车受电弓网检测系统 保障高速铁路安全高效运行
  • 超越“系统性沉默”:“AI元人文”构想下的价值范式转换与游戏化探索
  • 通信协议(Http,websocket)
  • 详细介绍:go语言学习记录9.23
  • npm install 时包库找不到报错解决 - 实践
  • MATLAB 仿真无线传感器网络(WSN)三大经典场景
  • P13382 解题报告
  • 免费搜索下载ICON图标的网站
  • 6ES7592-1BM00-0XA0 32路dq接线端子
  • 轻松掌握:用 Python 的 pdfminer 将 PDF 内容保存为 Word 文档 - 详解
  • 我最常用的快捷键
  • WPF多语言实现
  • 16 倍性能提升,成本降低 98%! 解读 SLS 向量索引架构升级改造
  • unity设置外置文件,运行读取文件获取地址
  • Microsoft Agent Framework/C#:了解Workflows的几种不同模式
  • CodeForces-374D Inna and Sequence
  • 字符串过长导致编译报错的问题及解决办法 - 详解
  • 厨房电秤方案:介绍一款电子秤芯片sic8632
  • CodeForces-1183F Topforces Strikes Back
  • Excel 实现下拉多选功能
  • CF981F Round Marriage
  • macOS直接使用pip安装报错
  • 2025 年最新螺旋地桩厂家推荐排行榜:聚焦光伏大棚等场景,甄选优质实力企业桩尖/大棚/组合/地螺丝螺旋地桩厂家推荐
  • CodeForces-1620D Exact Change
  • Python爬虫:获取某平台数据的下载链接 - 指南
  • 厨房电子秤芯片方案:SIC8632
  • 《借力JBoltAI框架,Java技术开发公司开启高效开发新范式》