JS高级心法——作用域链

首先我们来看两个js中的代码:

<script  type="text/javascript">
  var c=5;
  function t1(){
	var	d=6
	function 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

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

时间: 2025-01-05 21:54:35

JS高级心法——作用域链的相关文章

第十八篇 js高级知识---作用域链

一直有想法去写写js方面的东西,我个人是最喜欢js这门语言,喜欢的他的自由和强大,虽然作为脚本语言有很多限制的地方,但也不失为一个好的语言,尤其是在H5出现之后.下面开始说说js的方面的东西,由于自己的能力有现,有点地方说的不明白,还请高手指点.这个文章,如果有时间的话应该会写一个系列,包括js的高级方面的知识,最终希望能够说到js的引擎方面的东西.千里之行,始于足下,下面开始说说最简单的一个东西—js的作用域链,时常也比较容易弄错,也算是自己做一个纪录. 首先看一段代码: function t

js中的作用域链

js中的执行环境: 所谓执行环境(有时也称环境)它是JavaScript中最为重要的一个概念.执行环境定义了变量或函数有权访问的其他数据 ,决定了它们各自的行为.而每个执行环境都有一个与之相关的变量对象,环境中定义的所有变量和函数都保存在这个对象中. js中的作用域链: 每个函数都有自己的执行环境,当代码在执行环境中执行时,就会创建变量对象的作用域链.作用域链保证了对执行环境有权访问所有变量和函数的有序访问.作用域链的前端,始终都是当前执行的代码所在的环境的变量对象,如果环境是一个函数,那么它的

JS详细图解作用域链与闭包

JS详细图解作用域链与闭包 攻克闭包难题 初学JavaScript的时候,我在学习闭包上,走了很多弯路.而这次重新回过头来对基础知识进行梳理,要讲清楚闭包,也是一个非常大的挑战. 闭包有多重要?如果你是初入前端的朋友,我没有办法直观的告诉你闭包在实际开发中的无处不在,但是我可以告诉你,前端面试,必问闭包.面试官们常常用对闭包的了解程度来判定面试者的基础水平,保守估计,10个前端面试者,至少5个都死在闭包上. 可是为什么,闭包如此重要,还是有那么多人没有搞清楚呢?是因为大家不愿意学习吗?还真不是,

JS高级(三)--原型链、闭包、作用域、函数的四种调用方式

一.原型链(家族族谱) 概念:JS里面的对象可能会有父对象,父对象还会有父对象,.....祖先 根本:继承 属性:对象中几乎都会有一个__proto__属性,指向他的父对象 意义:可以实现让该对象访问到父对象中相关属性 根对象:Object.prototype var arr=[1,3,5] arr.__proto__:Array.prototype arr.__proto__.__proto__就是找到了根对象 function Animal(){} var cat=new Animal();

JS闭包、作用域链、垃圾回收、内存泄露相关知识小结

补充: 闭包(closure)是Javascript语言的一个难点,也是它的特色,很多高级应用都要依靠闭包实现. 闭包的三个特性: 1.函数嵌套函数 2.函数内部可以引用外部的参数和变量 3.参数和变量不会被垃圾回收机制回收 闭包的定义及其优缺点: 闭包 是指有权访问另一个函数作用域中的变量的函数,创建闭包的最常见的方式就是在一个函数内创建另一个函数,通过另一个函数访问这个函数的局部变量 闭包的缺点就是常驻内存,会增大内存使用量,使用不当很容易造成内存泄露. 闭包是javascript语言的一大

js闭包和作用域链

闭包 闭包 函数对象之间可以通过作用域链相互关联起来,函数体内部的变量都可以保存在函数作用域内 这种特性称做“闭包”. 什么是变量? 变量就是为一切事物赋的一个name; var的作用,初始化变量. 变量作用域 程序源码中定义这个变量的区域就就是变量作用域.(名字放在什么地方了) 全局变量拥有全局作用域,在js代码的任何地方都是有定义的.(这个名字很响亮) 在函数体内声明的变量在函数体内有效,他们是局部变量,函数参数也是局部变量他们只在函数体内有定义.(里层的能拿到的外层的值,外层的拿不到里层的

JS高级——Function原型链

基本概念 1.函数可以通过Function new出来,那么Function可以被称作构造函数,被new出来的函数可以被称为一个对象 2.Function既然是构造函数,那么肯定也有原型,它的原型是一个空的函数 3.Function的原型对象的原型对象最终指向的是object.prototype 原型链图 由上面基本概念衍生出的原型链图 1.Person构造函数,它既然是函数,那么肯定可以通过Function创建出来,那么就可以被当作对象 2.P对象还是函数对象,最后指向的都是object.pr

JS基础语法---作用域链

从函数嵌套来分析: (层数一般5层内) var num=10; function f1() { var num=20; function f2() { var num=30; function f3() { var num=50; console.log(num); } f3(); } f2(); } f1(); 看下图理解相对应的作用域: 原文地址:https://www.cnblogs.com/jane-panyiyun/p/11956999.html

js中作用域链的问题

为什么没有var声明的变量是全局的? 是因为,在js中,如果某个变量没有var声明,会自动到上一层作用域中去找这个变量的声明语句,如果找到,就使用,如果没有找到,继续向上查找,一直查找到全局作用域为止,如果全局中仍然没有这个变量的声明语句,那么会自动在全局作用域进行声明,这个就是js中的作用域链 <script> var i = 10; function f1() { //第一层 i = 20; function f2() { //第二层 i = 30; function f3() { //第