网站首页 > 技术文章 正文
变量作用域
变量的作用域值的是变量的生命周期和作用范围(全局与局部作用域的区别)。
静态作用域
静态作用域有称为词法作用域,即指其在编译阶段就可以决定变量的引用。静态作用域只与变量定义的位置有关与代码执行的顺序无关。
var x = 0; function foo() { alert(x); } function bar() { var x = 20; foo(); } foo();
动态作用域
动态作用域的变量引用只可在程序运行时刻决定(其通常通过动态栈来进行管理)。
var x = 0; function foo() { alert(x); } function bar() { var x = 20; foo(); } foo();
控制台打印出来:
JavaScript 变量作用域
(1)使用静态作用域
(2)函数作用域,就是只有 function 用于可以定义作用域
(3)ES6之后,块级作用域
词法环境
组成
词法环境用来描述静态作用域的数据结构。它由环境记录和外部词法环境的引用组成。
- 环境记录(record)(指形参,变量,函数等)
- 外部词法环境的引用(outer)
创建
在一段代码执行之前,先初始化词法环境。会被初始化的有:
- 形参
- 函数定义(创建函数对象,会保存当前作用域。见下图)
- 变量定义(所有初始化值均为 undefined)
结构
var x = 10; function foo(y) { var z = 30; function bar(q) { return x + y + z + q; } return bar; } var bar = foo(20); bar(40);
全局词法作用域(初始化状态)
函数词法作用域
关于词法环境的问题
命名冲突
形参,函数定义,变量名称命名冲突。其中的优先级的排序如下:
函数定义 > 形参 > 变量
arguments 的使用
为函数中定义好的变量。
函数表达式与函数定义的区别
- 函数表达式是在执行时才创建函数对象。
- 函数定义为在代码执行之前就进行创建的。
with 语句(慎用)
with 会创造一个临时作用域。
var foo = 'abc'; with({ foo: 'bar'; }) { function f() { alert(foo); }; (function() { alert(foo); })(); f(); }
try-catch 句法
try { var e = 10; throw new Error(); } catch (e) { function f() { alert(e); } (function() { alert(e); })(); f(); }
带名称的函数表达式
当一个函数表达式有了名称之后,JavaScript 会创建一个新的词法环境。并在这个词法环境中用有一个属性 A 指向这个函数,同时这个属性 A 指向的函数是不可被修改的。
下面例子为不常规的写法
(function A(){ A = 1; alert(A); })();
运行期个作用域变量:
猜你喜欢
- 2024-09-26 C语言存储类之内部链接的静态变量
- 2024-09-26 零基础学C语言——作用域(c语言:作用)
- 2024-09-26 C/C++关键字static作用解析(c++中static关键字)
- 2024-09-26 这个offer你吃定了!C++「面试真题」及基本知识点总结
- 2024-09-26 extern关键字详解(explain关键字)
- 2024-09-26 【python 基础篇 十四】python函数的作用域
- 2024-09-26 PHP入门读书笔记(三): 常量和变量
- 2024-09-26 静态变量使用场景?(静态变量使用场景)
- 2024-09-26 C语言static关键字的全面深入探讨
- 2024-09-26 Excel-VBA教程005,什么是变量,变量的类型、变量的作用域?
- 1515℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 575℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 514℃MySQL service启动脚本浅析(r12笔记第59天)
- 487℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 486℃启用MySQL查询缓存(mysql8.0查询缓存)
- 470℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 450℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 448℃MySQL server PID file could not be found!失败
- 最近发表
-
- 宝塔面板Nginx如何提高网站访问速度?
- 接口调试工具ApiPost中form-data/x-www-form-urlencoded/raw区别
- 高并发场景下,Nginx性能如何提升10倍?
- 高并发场景下,Nginx如何抗住千万级流量?
- 浏览器中在线预览pdf文件,pdf.mjs插件实现web预览pdf
- 为什么你的网站加载慢?90%的人忽略了这2个设置。
- 别再无脑复制Nginx配置了!掌握这10个"性能核弹"级参数
- 你的Nginx配置,可能就是你网站最慢的一环,注意这几个优化参数
- 深入浅出HTTP压缩技术(http2压缩)
- C程序设计之:1-1/2+1/3-... + 1/n 的和
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (83)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)