JS高级心法——作用域链

2024-05-23 21:58
文章标签 js 高级 作用域 心法

本文主要是介绍JS高级心法——作用域链,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先我们来看两个js中的代码:   
<script  type="text/javascript">  var c=5;function t1(){	var	d=6function t2(){var e=7		 alert(c+d+e);		}t2();}t1(); 
</script>
  这个你很快会得出结论:18;

<script language="javascript" type="text/javascript">function t1(){	var d;function t2(){d=5;e=6;}t2();}t1();alert(e);  alert(window.d);
</script>
     

   思考下?……

你的答案是 6,undefined吗?如果不是请继续往下看吧,这其实就是作用域链的问题。

   我们知道js中用var声明一个变量 ,寻找变量首先在函数内寻找,找不到则再往外层寻找直到全局(window)区域。这就是第一个程序的依据
   window.xxx引用全局变量,找不到作为某个属性不存在,则返回undefined。

   好了再看一个:

<script  type="text/javascript">   var str1='global';function t1(){	alert(str1);alert(str2);var str2='local';	  }t1();	
</script>

    这个如果你在网上查好多关于作用域的都有这个例子来解释,但是看了他们洋洋洒洒写了好多结果自己越看越迷糊。

    历经千辛万苦终于得出了很实用的方法,免得看太多让人头晕的东西。

其实js代码在整体运行时分为:词法分析期运行期   

    词法分析分析3样东西:第一步:先分析参数
                        第二步:再分析变量声明
                        第三步:分析函数声明
   具体: 0:函数运行前瞬间生成活动对象Actve Object(AO)
          1:
             1.1函数声明的参数形成AO的属性值全是undefined
             1.2接收实参,形成AO相应的属性的值
          2:分析变量声明!
             如果AO上还没有属性,则添加AO属性,值是undefined
             如果已经有属性,则不做任何影响
          3.分析函数声明,如果函数属性已经存在,则被覆盖。

   依据整理分析下下面:

<script  type="text/javascript">   function t2(age){var age=99;alert(age); }t2(5);//运行结果是99
</script>
分析过程:

0:形成AO={}

1.分析形参age为undefined

2.分析var age 发现AO已经有age属性,不做任何影响

执行过程:AO.age=99;

alert(age)结果为99

明白了作用域链分析出结果我们才能更好的明白视频中讲解的例子,以后再也不用担心自己找不到“北”了!



这篇关于JS高级心法——作用域链的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/996528

相关文章

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

在Node.js中使用.env文件管理环境变量的全过程

《在Node.js中使用.env文件管理环境变量的全过程》Node.js应用程序通常依赖于环境变量来管理敏感信息或配置设置,.env文件已经成为一种流行的本地管理这些变量的方法,本文将探讨.env文件... 目录引言为什么使php用 .env 文件 ?如何在 Node.js 中使用 .env 文件最佳实践引

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?