JavaScript之变量、作用域

一.变量

1.基本类型值和引用类型值

js和其他语言一样也分值类型和引用类型。在基本概念那篇博客也纪录了五种常见的基本数据类型:Undefined、Null、Boolean、Number、String。这五种都是按值访问的基本数据类型,可以操作保持在变量中的实际的值.(js和其他语言C#不同的是String也是基本数据类型)。

引用类型的值是保存在内存中的对象。js不允许直接访问内存中的对象,不能直接操作对象的内存空间。操作对象是是操作的对象的引用。对于引用类型的值可以为它动态的添加属性。

2.变量值的拷贝

这个和C#的类似,基本数据类型是直接创建一个新的变量,对于引用类型是将变量指向赋值对象的堆地址。

3.传递参数

js中所有的函数的参数都是按值传递。把函数外部的值复制给函数内部的参数。传递参数和变量值拷贝一样。在向函数传递引用类型的值时,会把这个值在内存中的地址复制给一个局部变量,这个局部变量的变化会反映在函数外部(类似C#)。

4.检测类型

要检测一个基本类型的变量用typeof是极好的,但对于一个对象或null,用type始终返回object,这样就不是极好的了。这时候instanceof出场了。有了它可以检测出它是什么类型的对象,是数组、还是正则等。

二、执行环境和作用域

1. 执行环境定义了变量或函数有权访问的其他数据。每个执行环境都有一个与之关联的变量对象,环境中定义的所有变量和函数都保存在这个对象中。

全局执行环境是最外围的一个执行环境。宿主不同所表示的执行环境的对象也不一样。在web浏览器中,全局执行环境被认为是window对象。

每个函数都有自己的执行环境。当执行流进入一个函数时,函数的环境就被推入一个环境栈中,当函数执行之后,栈将其弹出,把控制权交给之前的执行环境。

作用域链书上介绍的有点过于仔细,意思和生命周期差不多,就是看你这个变量能被访问的地方。

用try-catch、with来延长作用域链。

2.js没有块级作用域

<script type="text/javascript">
    if(true)
    {
        var color="blue";

    }
    alert(color); // blue
    for(var  i=0;i<5;i++);
    alert(i); //5
    function FunA()
    {

         for(var  j=0;j<5;j++);

         return j;

    }
    var  result=FunA();
    alert(result); //5
//    alert(j); //出错 不再向下执行

    for(var m=0;m<5;m++);
    alert(m); //5

</script>

看到上面代码测试可能做过C#这些的会感到奇怪,包括我。其实在js中一点也不奇怪。在js中是没有块级作用域。用var声明的变量会添加到最近的环境中,在函数内部,最接近的的环境是函数的局部环境,在with语句中,最接近的环境是函数环境。如果未使用var声明,变量会自动添加到全局变量中。

时间: 2024-11-09 09:22:58

JavaScript之变量、作用域的相关文章

[转]深入理解JavaScript的变量作用域

1.JavaScript的作用域链 2.函数体内部,局部变量的优先级比同名的全局变量高. 3.JavaScript没有块级作用域. 4.函数中声明的变量在整个函数中都有定义. 5.未使用var关键字定义的变量都是全局变量. 6.全局变量都是window对象的属性 在学习JavaScript的变量作用域之前,我们应当明确几点: JavaScript的变量作用域是基于其特有的作用域链的. JavaScript没有块级作用域. 函数中声明的变量在整个函数中都有定义. 1.JavaScript的作用域链

JavaScript的变量作用域深入理解

在学习JavaScript的变量作用域之前,我们应当明确几点: a.JavaScript的变量作用域是基于其特有的作用域链的. b.JavaScript没有块级作用域. c.函数中声明的变量在整个函数中都有定义. <script> var x = 1; function outer() { var y = 2; function inner() { var z = 4; alert(x); } inner(); } outer(); </script> alert(x)这句代码,J

深入理解JavaScript的变量作用域(转载Rain Man之作)

在学习JavaScript的变量作用域之前,我们应当明确几点: JavaScript的变量作用域是基于其特有的作用域链的. JavaScript没有块级作用域. 函数中声明的变量在整个函数中都有定义. 1.JavaScript的作用域链 首先看下下面这段代码: <script type="text/javascript"> var rain = 1; function rainman(){ var man = 2; function inner(){ var innerVa

深入理解JavaScript的变量作用域

在学习JavaScript的变量作用域之前,我们应当明确几点: JavaScript的变量作用域是基于其特有的作用域链的. JavaScript没有块级作用域. 函数中声明的变量在整个函数中都有定义. 1.JavaScript的作用域链 首先看下下面这段代码: 1 <script type="text/javascript"> 2 var rain = 1; 3 function rainman(){ 4 var man = 2; 5 function inner(){ 6

第九章 Javascript之变量作用域

分析: 无论是强类型语言c#.c++.java等语言,还是弱类型语言如Javascript,所有变量可以抽象为两种类型,即局部变量和全局变量. 全局变量:整个作用域可见. 局部变量:局部可见,退出作用域,就被GC销毁,回收空间. Code分析: //局部变量 function PartVary() { var n = 10; //表示局部变量,外部不可访问 } PartVary(); alert(n);//error //全局变量 function AllVary() { n = 10 //表示

自学JavaScript(一) 变量-作用域

JavaScript 作用域 作用域—可访问变量的集合. 全局变量或者函数可以覆盖window对象的变量或者函数: 局部变量和window对象可以覆盖全局变量和函数. JavaScript 作用域 在 JavaScript 中, 对象和函数同样也是变量. 在 JavaScript 中, 作用域为可访问变量,对象,函数的集合. JavaScript 函数作用域: 作用域在函数内修改. 注:因为局部变量只作用于函数内,所以不同的函数可以使用相同名称的变量. 局部变量在函数开始执行时创建,函数执行完后

JavaScript的变量作用域

http://www.cnblogs.com/rainman/archive/2009/04/28/1445687.html tag:作用域链 作用域 声明提升 全局变量 http://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/0014344993159773a464f34e1724700a6d5dd9e235ceb7c000 tag:变量作用域 声明提升 全局作用域 命名冲突 ES6(

JavaScript&amp;jQuery.变量作用域

变量作用域 变量的位置或影响它的作用范围,这个作用范围也叫作用域. 如果变量是在函数内声明的,那么的作用域仅在函数内,函数之外不能调用.函数调用执行完后,函数内的变量立即销毁. function getArea(length,width){     // 局部变量area,在函数调用后立马销毁     var area= length*width;     return area; } 如果变量是在函数外声明的,它的作用域是全局的,也叫全局变量.在页面被浏览器加载后,全局变量一直存于内存中,直到

关于javascript函数变量作用域问题

作用域 1.如果一个变量在函数体内部申明,则该变量的作用域为整个函数体,在函数体外不可引用该变量: 2.JavaScript的函数在查找变量时从自身函数定义开始,从"内"向"外"查找.如果内部函数定义了与外部函数重名的变量,则内部函数的变量将"屏蔽"外部函数的变量.

JavaScript 关于变量作用域的一道面试题

ShineJaie 原创,转载请注明出处. 昨晚在一个交流群里看到有位网友提了一个他的面试题求助答疑.刚好我也有看到,就对这个问题思考了一下,觉得这道题对理解 JavaScript 作用域还是很有帮助的,特此又把自己的解题思路梳理了一遍,希望对其它人有所帮助. 首先看下面试题: 1 var arr = [1, 2, 3]; 2 for (var i = 0, j; j = arr[i++];) { 3 console.log(j); 4 } 5 6 console.log('---------'