0

0

js中function函数的使用方法【教程】

穿越時空

穿越時空

发布时间:2025-12-13 12:06:40

|

376人浏览过

|

来源于php中文网

原创

JavaScript中function函数有七种使用方法:一、声明函数(具名、可提升);二、表达式函数(匿名、不可提升);三、箭头函数(简洁、不绑定this);四、IIFE(立即执行、隔离作用域);五、构造函数(new调用、创建实例);六、作为参数(高阶函数、回调);七、递归函数(自调用、需终止条件)。

js中function函数的使用方法【教程】 - php中文网

在JavaScript中,function函数是定义可重复执行代码块的核心语法。以下是function函数的多种使用方法:

一、声明函数

使用function关键字定义命名函数,该函数会被提升(hoisting),可在声明前调用。

1、使用function关键字后接函数名、括号和花括号定义函数。

2、在括号内可声明零个或多个参数,用于接收调用时传入的值。

3、在花括号内编写执行语句,可包含return语句返回结果。

二、表达式函数

将函数赋值给变量,形成函数表达式。该方式不会被提升,必须先定义后调用。

1、使用const或let声明变量,并将function关键字开头的函数体赋值给该变量。

2、函数名可省略,构成匿名函数表达式。

3、调用时通过变量名加括号执行,如myFunc()

三、箭头函数

ES6引入的简洁语法,不绑定自己的this、arguments、super或new.target,适合简短逻辑和回调场景。

1、当只有一个参数时,可省略小括号,如x => x * 2

2、当函数体为单条return语句时,可省略花括号和return关键字。

3、当需要返回对象字面量时,必须用小括号包裹,避免与代码块混淆,如() => ({id: 1})

四、立即执行函数表达式(IIFE)

定义后立即调用的函数,常用于创建独立作用域,防止变量污染全局环境。

1、将函数表达式用小括号包裹,使其成为表达式而非声明。

腾讯交互翻译
腾讯交互翻译

腾讯AI Lab发布的一款AI辅助翻译产品

下载

2、在末尾添加另一对小括号并传入参数,触发立即执行。

3、可使用!function(){}()+function(){}()等前缀形式实现同样效果。

五、构造函数调用

使用new关键字调用函数,会创建新对象并将其绑定为this,适用于模拟类实例化行为。

1、函数内部使用this为新对象添加属性或方法。

2、函数应避免使用return原始值,否则不影响新对象创建;若返回对象,则替代默认返回值。

3、调用时必须使用new前缀,否则this指向全局对象(非严格模式)或undefined(严格模式)。

六、作为参数传递的函数

函数可被当作值传入其他函数,实现高阶函数逻辑,如map、filter、setTimeout等均依赖此特性。

1、在调用接受函数的API时,直接传入已定义的函数名,不带括号。

2、可传入匿名函数或箭头函数,避免额外命名开销。

3、确保传入函数的参数数量与接收方预期一致,否则可能产生<strong><span>undefined</span></strong>或运行时错误。

七、递归函数

函数在内部调用自身,适用于处理具有自相似结构的问题,如阶乘、树遍历等。

1、必须设置明确的终止条件,否则导致无限调用和溢出。

2、递归调用时需更新参数,逐步逼近终止条件。

3、命名函数可通过函数名调用自身;匿名函数表达式需借助<strong><span>arguments.callee</span></strong>(已废弃)或预先赋值变量引用。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
es6新特性
es6新特性

es6新特性有:1、块级作用域变量;2、箭头函数;3、模板字符串;4、解构赋值;5、默认参数;6、 扩展运算符;7、 类和继承;8、Promise。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

106

2023.07.17

es6新特性有哪些
es6新特性有哪些

es6的新特性有:1、块级作用域;2、箭头函数;3、解构赋值;4、默认参数;5、扩展运算符;6、模板字符串;7、类和模块;8、迭代器和生成器;9、Promise对象;10、模块化导入和导出等等。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

197

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2025.12.24

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

562

2023.09.20

python如何计算数的阶乘
python如何计算数的阶乘

方法:1、使用循环;2、使用递归;3、使用math模块;4、使用reduce函数。更多详细python如何计算数的阶乘的内容,可以阅读下面的文章。

177

2023.11.13

python求阶乘教程大全
python求阶乘教程大全

本专题整合了python求阶乘相关教程,阅读专题下面的文章了解更多详细内容。

13

2025.11.08

python语言求阶乘
python语言求阶乘

本专题整合了python中阶乘相关教程,阅读专题下面的文章了解更多详细步骤。

43

2025.12.06

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号