自己怎么做优惠卷网站,金蓝盟企业管理咨询公司,企业网站系统,网站设计怎么验收一、执行环境 执行环境定义了变量或函数有权访问的其他数据#xff0c;决定了它们的各自行为。每个执行环境都有一个与之关联的变量对象#xff0c;环境中定义的所有变量和函数都保存在这个对象中。虽然我们无法访问这个对象#xff0c;但是解析器在处理数据时会在后台使用它…一、执行环境 执行环境定义了变量或函数有权访问的其他数据决定了它们的各自行为。每个执行环境都有一个与之关联的变量对象环境中定义的所有变量和函数都保存在这个对象中。虽然我们无法访问这个对象但是解析器在处理数据时会在后台使用它。 全局执行环境是最外围的一个环境根据JavaScript实现所在的宿主环境不同表示执行环境的对象也不一样。在web浏览器中全局执行环境被认为是window对象因此所有全局变量和函数都是作为window对象的属性和方法创建的。 某个执行环境中的所有代码执行完毕后该环境被销毁保存在其中的所有变量和函数定义也随之销毁全局执行环境直到应用程序退出比如关闭网页和浏览器时才会被销毁。 每个函数都有自己的执行环节。当执行流进入一个函数时函数的环境就会被推入一个环境栈中。函数执行完之后栈将其环境弹出把控制权返回给之前的执行环境。
二、作用域 当代码在一个环境中执行时会创建变量对象的一个作用域链。作用域链的用途是保证对执行环境有权访问的所有变量和函数的有序访问。作用域链的前端始终都是当前执行的代码所在环境的变量对象。如果这个环境是函数则将其活动对象作为变量对象。活动对象在最开始时只包含一个变量即arguments对象这个对象在全局环境中是不存在的。作用域链的下一个变量对象来自于包含外部环境在下一个变量外部环境对象则来自下一个包含环境这样一直延续到全局执行环境全局执行环境的对象始终都是作用域链中的最后一个对象。 标识符解析是沿着作用域链一级一级地搜索标识符的过程。搜索过程始终从作用域链的前端开始然后逐级向后回溯直至找到标识符为止比如下面的代码
var color blue;
function changeColor(){if (color blue){color red;} else {color blue;}
}
changeColor();
alert(Color is now color); 以上示例中函数changeColor()的作用域包含两个对象它自己的变量对象其中定义着arguments对象和全局环境的变量对象(color)。可以在函数内部访问变量color就是因为可以在这个作用域链中找到它。 此外在局部作用域中定义的变量可以在局部环境中与全局变量互换使用比如下面的例子
var color blue;
function changeColor(){var anotherColor red;function swapColors(){var tempColor anotherColor;anotherColor color;color tempColor; //这里可以访问color, anotherColor和tempColor} //这里可以访问color、anotherColor但不能访问tempColor swapColors();
}
changeColor(); //这里只能访问color延长作用域链 虽然执行环境的类型总共只有两种——全局和局部函数但还是有其他办法来延长作用域链。有些语句可以在作用域链的前端临时增加一个变量对象该变量对象会在代码执行后被移除。在两种情况下会发生这种现象。具体来说就是当执行流进入下列任何一个语句时作用域链就会得到加长 try-catch 语句的 catch 块。 with 语句。 这两个语句都会在作用域链的前端添加一个变量对象。对WITH语句来说将会指定的对象添加到作用域链中。对catch语句来说会创建一个新的变量对象其中包含的是被抛出的错误对象的声明。
function builderUrl(){var qs?debugtrue;with(location){var url href qs; }return url;
} 以上示例中with语句接受的是location对象因此其变量对象中就包含了Location对象的所有属性和方法而这个变量对象被添加到了作用域链的前端。builderUrl()函数中定义了一个变量qs。当在with语句中引用变量href时实际引用的是location.href可以在当前执行环境的变量对象中找到。当引用变量qs时引用的则是在buildUrl()中定义的那个变量而该变量位于函数环境的变量对象中。至于with语句内部则定义了一个名为url的变量因而url就成了函数执行环节的一个部分所以可以作为函数的值被返回。 没有块级作用域 JavaScript没有块级作用域而在其他语言中由大括号封闭的代码块都有自己的作用域因此支持根据条件定义变量。
if(true){var colorblue;
}
alert(color); //if语句执行完后变量color依然能被访问
for(var i0;i10;i){doSomething(i);
}
alert(i); 对于有块级作用域的语言来说for语句初始化变量的表达式所定义的变量只会存在于循环的环境之中。而对于JavaScript来说由for语句创建的变量i即使在for循环结束后也依旧会存在于循环外部的执行环境中。 但是在函数内部用var声明的变量在函数外面是访问不到的比如
function a(){var b1;
}
console.log(b) //这一行会导致错误因为b只能在函数a当中访问 var和let的区别 前面的文章讲过在JavaScript中除了可以用var声明变量之外还可以用let声明变量与var不同使用let关键字在块作用域中声明的变量是无法被块作用域之外访问的详情请参见博文
JavaScript中的变量、关键字、保留字-CSDN博客 本文部分内容参考《JavaScript高级编程》