JavaScript闭包、原型链、事件循环,一文彻底讲明白(小白也能懂)

你是不是也看过无数文章,却被"闭包是函数嵌套"、"原型链就是__proto__"、"事件循环是宏任务微任务"搞得一头雾水?别急,今天我用生活比喻+代码实例,带你30分钟彻底搞懂JavaScript三大核心概念,从此面试不再慌!

一、闭包:函数的"记忆体"

什么是闭包?

简单说:一个函数记住了它创建时的环境,即使外部函数执行完了,它依然能访问那个环境里的变量。

🌰 比如你去奶茶店点单,服务员记住了你上次说"少糖",这次你还没说,她就知道怎么做------这就是"记忆"。

复制代码
function outer() {
    let name = "小明";
    function inner() {
        console.log(name); // 能访问到name
    }
    return inner;
}
const fn = outer();
fn(); // 输出:小明 → 闭包形成!

✅ 闭包用途:封装私有变量、防抖节流、模块化。

🔗 二、原型链:JS的"家族传承"

JS中没有类,对象怎么继承?靠原型链!

每个对象都有一个 proto(或 [[Prototype]]),指向它的"爸爸"(构造函数的 prototype)。

🌰 比如你爷爷会打铁,爸爸会,你也会------这就是"链式传承"。

复制代码
function Person(name) {
    this.name = name;
}
Person.prototype.sayHi = function() {
    console.log("你好,我是" + this.name);
};

const p = new Person("小红");
p.sayHi(); // 你好,我是小红
// p → 找sayHi → 没有 → 去__proto__找 → 找到了!

✅ 记住一句话:当你调用一个方法,JS会沿着 proto 一直往上找,直到 null ------ 这就是原型链。

⏳ 三、事件循环:JS的"单线程大脑"

JS是单线程,但为什么能异步?靠事件循环(Event Loop)!

🌰 比如你在餐厅吃饭:

先点菜(同步代码)

然后告诉服务员"菜好了叫我"(setTimeout)

你继续刷手机(不卡住)

菜好了,服务员叫你(回调执行)

复制代码
console.log(1);
setTimeout(() => console.log(2), 0);
Promise.resolve().then(() => console.log(3));
console.log(4);

// 输出顺序:1 → 4 → 3 → 2

✅ 执行顺序:

同步代码 → 微任务(Promise) → 宏任务(setTimeout)

✅ 总结一句话:

闭包:函数记住"过去"的变量

原型链:对象向上"找爸爸"

事件循环:JS一边干活一边"等通知"

🔥 收藏这篇,面试官再问,你直接稳稳回答,还能讲得通俗易懂!

👉 关注我,下期讲《Vue响应式原理,一张图看懂》!

你觉得哪个最难?评论区聊聊! 💬

相关推荐
那个失眠的夜11 分钟前
AspectJ
java·开发语言·数据库·spring
网域小星球31 分钟前
C++ 从 0 入门(四)|继承、多态、this 指针、深浅拷贝(C++ 面试终极收官)
开发语言·c++·面试·多态·继承·this指针·深浅拷贝
CoderYanger1 小时前
14届蓝桥杯省赛Java A 组Q1~Q3
java·开发语言·线性代数·算法·职场和发展·蓝桥杯
钮钴禄·爱因斯晨1 小时前
他到底喜欢我吗?赛博塔罗Java+前端实现,一键解答!
java·开发语言·前端·javascript·css·html
布说在见1 小时前
企业级 Java 登录注册系统构建指南(附核心代码与配置)
java·开发语言
草莓熊Lotso1 小时前
一文读懂 Java 主流编译器:特性、场景与选择指南
java·开发语言·经验分享
疯狂成瘾者1 小时前
Java 常见 Map 对比总结:HashMap、LinkedHashMap、TreeMap、ConcurrentHashMap
java·开发语言·spring
XMYX-01 小时前
16 - Go 协程(goroutine):从基础到实战
开发语言·golang
txxzjmzlh1 小时前
Thread 类的基本用法
java·开发语言
machnerrn2 小时前
matlab实现直流伺服电机 PID 控制系统仿真系统(含源码+资料报告+说明文档等)
开发语言·matlab