news 2026/4/17 6:38:33

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
js函数声明和函数表达式的理解

在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.chartContainer

const 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。

目前是:先使用后定义,那么在运行的时候会报错吗?

答案是:不会的。

因为:这里有一个重要的执行时机差。实际上在调用前,已经被定义了。

我们被代码的先后顺序给误导了。

并不是说:定义函数表达式的代码必须要写在函数调用之前。

异步执行时机

const resizeObserver = new ResizeObserver(() => {

resizeFn() // 这里不会立即执行!

})

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

代码执行顺序

// 步骤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)

尾声

如果你看了有收获,请给我点一个推荐

如果给我打赏了,那保证你未来大富大贵

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 22:35:28

【毕业设计】基于springboot的汽车租赁买卖管理系统的设计与实现(源码+文档+远程调试,全bao定制等)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/4/18 3:27:40

奶奶都能看懂的 C++ —— vector 与迭代器

但是在讲解它之前,我们需要先了解迭代的对象是什么。常见的一种,叫做 vector。vector 类型使用可变有序序列我们知道,数学里,vector 是向量的意思。但 C 里的向量和它不太一样。它的含义是,具有可变元素个数的有序对象…

作者头像 李华
网站建设 2026/4/5 11:03:23

基于java的SpringBoot/SSM+Vue+uniapp的校园活动管理系统的详细设计和实现(源码+lw+部署文档+讲解等)

文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaitsPlus系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言 🌞博主介绍:✌全网粉丝15W,CSDN特邀作者、211毕业、高级全…

作者头像 李华
网站建设 2026/4/17 19:36:30

MPK(Mirage Persistent Kernel)源码笔记(1)--- 基础原理

x00 概要 CMU 贾志豪老师团队提出的MPK(Mirage Persistent Kernel)是依托 Mirage 编译器生态的创新运行时系统,其核心能力在于将多GPU环境下大语言模型(LLM)推理任务自动转换为适配GPU架构的高性能巨型内核&#xff0…

作者头像 李华
网站建设 2026/4/8 6:09:10

PHP 异常处理全攻略 Try-Catch 从入门到精通完全指南

什么是 Try-Catch? Try-catch 是 PHP 处理异常的机制——程序执行期间发生的意外事件或错误。与其让应用程序崩溃,try-catch 允许你拦截这些错误并优雅地处理它们。 把它想象成一张安全网。你“尝试”执行可能失败的代码,如果失败了&#xf…

作者头像 李华
网站建设 2026/4/15 23:49:05

达梦数据库安装

好的,这是一篇关于达梦数据库(DM Database)安装的详细指南,包含目录、文字说明和图片位置示意,内容丰富,力求达到3000字的要求。达梦数据库安装与配置详细指南目录引言1.1 达梦数据库简介1.2 安装前准备的重…

作者头像 李华