JS 底层探究--上下文

开始接触前端的时候 都是从HTML/CSS/JS 三大基础来的。

HTML: 页面布局

CSS: 样式美化

JS: 实现动态交互

可以实现一些简单的页面和需求。

从来都是需要实现啥?然后搜怎么实现?最后拼凑出一段实现的代码。

但是其中的原理,为啥用这个属性就能达到效果,为啥这里要这么写,从来没有仔细的探究过。

这里我们就抛弃掉工作中的效率为王的准则。来对一些小点进行深挖探究。

一、上下文是啥?

执行上下文 = JavaScript 代码运行时的 "运行环境 + 数据仓库 + 规则手册"

每一个上下文,天生自带 3 个核心内容

  1. 变量环境:存变量、函数、参数
  2. 作用域链:能访问哪些外部变量
  3. this 指向:this 是谁

二、上下文有哪几种

JS 只有 2 种上下文(必须记住)

1. 全局上下文(整个程序的 "大厅")

代码一运行就创建

只有 1 个

关闭页面才销毁

放全局变量、全局函数

2. 函数上下文(函数的 "小房间")

调用函数时才创建

函数执行完立刻销毁

每次调用 = 新建一个房间

放局部变量、参数

一段代码看懂上下文切换

javascript 复制代码
// 1. 进入 【全局上下文】
let a = 1;

function test() {
  // 2. 调用函数 → 进入 【函数上下文】
  let b = 2;
  console.log(a + b);
} // 3. 函数执行完 → 销毁函数上下文

test();
// 4. 回到 【全局上下文】

注意点:

1、全局上下文只有一个,而且JS加载中一直存在

2、函数上下文可以有多个,只有函数被调用才会创建,执行完成进行销毁。

相关推荐
小满Autumn1 小时前
依赖注入设计模式速查手册
开发语言·c#·wpf·mvvm·依赖注入
周末也要写八哥1 小时前
浅谈:C++中cpp 14 ~ cpp 17
开发语言·c++·算法
不会C语言的男孩1 小时前
C++ Primer 第13章:拷贝控制
开发语言·c++
z落落1 小时前
C# 静态成员 vs 非静态成员(调用规则+内存特点)+只读和常量 const常量 / readonly / static readonly 三者终极区别
java·开发语言·c#
zhangfeng11331 小时前
超算中心 高性能计算 slurm的linux版本 centos7,如何安装docker,如何安装torch2.4
linux·运维·服务器·开发语言·人工智能·机器学习·docker
java1234_小锋1 小时前
LangChain4j 开发Java Agent智能体- 整合SpringBoot4
java·开发语言·langchain4j
我不是懒洋洋2 小时前
从零实现一个Redis客户端:RESP协议与网络编程
开发语言·c++
小小码农Come on2 小时前
Qt::WA_StyledBackground属性的作用
开发语言·qt
无风听海2 小时前
PKCE 的 S256 算法深度剖析:从协议设计到密码学原理
javascript·网络·算法·密码学