JavaScript基础——匿名函数

匿名函数简介

立即执行的匿名函数

作为回调函数

闭包


匿名函数简介

在平时我们定义函数时,一般会用function 函数名(){}的形式,这种形式定义的函数称为具名函数,也就是说这种函数有具体的函数名。

定义一个sayHello函数,这个函数的函数名就是sayHello,调用函数写作sayHello()。

javascript 复制代码
        // 1.有名字的函数(具名)
        function sayHello() {
            console.log('hello');
        }
        sayHello();

如果直接使用不带名称的函数,会报错SyntaxError: Function statements require a function name,因为函数必须要有名称。

如果不想定义名称,又想使用函数,应该使用匿名函数

在JavaScript中,提出了一种没有函数名称、不与任何标识符关联的函数,这种函数也叫做匿名函数。

函数只有调用了才能使用,而匿名函数没有名称,不能通过名称来调用,需要配合符号"+"、"-"、"()"等使用。

借助符号"+"、"-",使用函数,并用在函数后方使用()调用函数,注意匿名函数需要写分隔符";"

代码如下:

javascript 复制代码
        +function () {
            console.log('hello1');
        };

        // 匿名函数要加分割符号;
        -function () {
            console.log('hello2');
        };

立即执行的匿名函数

匿名函数还可以作为立即执行函数,在匿名函数后面直接使用()调用的函数,也就是自己执行函数代码块,这种函数就是立即执行函数,常用于避免污染全局命名空间,语法如下:

javascript 复制代码
        ; (function () { }())

定义一个立即执行的匿名函数,利用()符号定义匿名函数并加上分割符号,;(function(){}),在函数代码块后面使用()调用函数,写作;(function(){}()),输出hello world。

javascript 复制代码
        // 常见匿名函数 (这些直接调用的函数,叫做立即执行函数)
        ; (function () {
            console.log('hello world');
        }())

作为回调函数

在需要传递函数作为参数的情况下(使用定时器函数),使用匿名函数作为回调函数,代码如下:

javascript 复制代码
setTimeout(function() {
  console.log('Hello after 1 second!');
}, 1000);

闭包

匿名函数经常与闭包一起使用,以保持局部变量的作用域。

定义一个函数返回一个匿名函数,这样的形式就是一个闭包,匿名函数可以访问函数作用域的变量。

javascript 复制代码
        function createClosure() {
            var secret = 'I am a secret!';
            return function () {
                console.log(secret);
            };
        }
        var myClosure = createClosure();
        myClosure();
相关推荐
晓得迷路了几秒前
栗子前端技术周刊第 134 期 - React Router v8、TypeScript 7 RC、React Native 0.86...
前端·javascript·react.js
代码煮茶15 小时前
React 组件封装方法论 —— 以 Todo App 为例
javascript·react.js
任沫16 小时前
Agent之Function Call
javascript·人工智能·go
默_笙17 小时前
🛬 我让 AI 帮我写了一个打飞机游戏,结果 Canvas 把我整不会了
前端·javascript
梯度不陡17 小时前
AI 到底能不能从零写软件?ProgramBench 和 RepoZero 给出了两种答案
前端·javascript·面试
胡萝卜术19 小时前
滑动窗口最大值:从暴力到单调队列,层层优化全解析
前端·javascript·面试
kyriewen20 小时前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
铁皮饭盒21 小时前
bun直接tsx,优雅!
javascript·后端
_柳青杨1 天前
一文吃透 Node.js 事件循环:从原理到 Node 20+ 重大变更
javascript·后端
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法