JavaScript高级——作用域和作用链

1、概念理解:

------ 就是一块"地盘",一个代码所在的区域

------ 静态的(相对于上下文对象),在编写代码时就确定了

2、分类

① 全局作用域

② 函数作用域

③ 没有块作用域(ES6有了)

3、作用

① 隔离变量,不同作用域下同名变量不会有冲突

4、作用域与执行上下文的区别

①区别一:

全局作用域之外,每个函数都会创建自己的作用域,作用域在函数定义时就已经确定了。而不是在函数调用时。

全局执行上下文是在全局作用域确定之后,JS 代码马上执行之前创建。

函数执行上下文是在调用函数时,函数代码执行之前创建。

② 区别二:

作用域是静态的,只要函数定义好了就一直存在,且不会再变化。

执行上下文是动态的,调用函数时创建,函数调用结束时就会自动释放。

③ 区别三:

上下文环境(对象)是从属于所在的作用域。

全局上下文环境 ==> 全局作用域。

函数上下文环境 ==> 对应的函数使用域。

5、作用域链

① 实例1

本文分享到这里,欢迎大家评论区相互讨论学习,下一篇继续分享JavaScript高级学习中的循环遍历加监听的内容。

相关推荐
Qlittleboy12 分钟前
uniapp如何使用本身的字体图标
javascript·vue.js·uni-app
Days205013 分钟前
LeaferJS好用的 Canvas 引擎
前端·开源
charlie11451419116 分钟前
Kotlin 的 apply / with / run 详解
开发语言·kotlin·程序设计·面对对象
Tiger_shl21 分钟前
【层面一】C#语言基础和核心语法-02(反射/委托/事件)
开发语言·c#
小白菜学前端28 分钟前
vue2 常用内置指令总结
前端·vue.js
林_深时见鹿29 分钟前
Vue + ElementPlus 自定义指令控制输入框只可以输入数字
前端·javascript·vue.js
GDAL29 分钟前
Knockout.js 任务调度模块详解
javascript·knockout
椒盐螺丝钉29 分钟前
Vue组件化开发介绍
前端·javascript·vue.js
koooo~32 分钟前
v-model与-sync的演变和融合
前端·javascript·vue.js
GW_Cheng34 分钟前
分享一个vue2的tinymce配置
开发语言·javascript·ecmascript