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-10-01 22:02:54

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

局部变量-javascript中变量作用域的问题

问题描述 javascript中变量作用域的问题 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">

JavaScript的变量作用域深入理解_javascript技巧

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

关于javascript中变量作用域理解

现在就结合网上的一篇文章在重新回顾下作用域这个东西吧. 作用域和上下文并不是同一个东西,很多人可能会把它搞混.每一个函数调用都联系着一个作用域和一个上下文.根本上来说,作用域是基于函数的而上下文是基于对象的.换句话说,作用域与函数调用是能够获取的变量有联系,它对与每一次调用来说都是独一无二的.上下文常常代表this变量的值,它指向"拥有"当前执行的这段代码的对象. 变量作用域 一个变量的作用域是程序源代码中定义这个变量的区域.全局变量拥有全局作用域,在js代码里的任何地方都是有定义的.

JavaScript中变量作用域详细介绍

  以下变量具有全局作用域:     1.所有定义在最外层的变量(非函数体内部)具有全局作用域.     2.未定义直接赋值的变量,系统会把它声明为全局作用域.     3.所有window对象的属性具有全局作用域. 以下变量具有函数作用域   1. 在函数体内部用var定义的变量,这里要注意一点,只要是在函数里定义的变量,就算是在最       后一句定义,该变量也拥有整个函数的作用域.但是它的赋值是等到运行到那一句代码以         后才赋值的!!!   特别应该说明的一点是,作用域是层

javascript变量作用域一点总结

前言:javascript里变量作用域是个经常让人头痛抓狂的问题,下面通过10++个题目,对经常遇到又容易出错的情况进行了简单总结,代码样例很短很简单 题目一 var name = 'casper'; alert(name); //毫无疑问地输出:casper 题目二 alert(name); //报错:对象未定义,即使用一个压根就不存在的变量,所以出错 age = 24; //这里木有错,但age不是为定义吗?翻下犀牛书,明白了 //给一个未定义的变量赋值,会创建一个全局变量,相当于:var

javascript 与 jquery 变量作用域差异问题

问题描述 javascript 与 jquery 变量作用域差异问题 /***javascript例子***/ function fn(){ var oo="oo"; function fnn(){ alert(oo); } fnn(); } fn(); // 结果 undefined /***jquery 例子***/ $( function(){ var oo="oo"; function fnn(){ alert(oo); } fnn(); } ) // 结果

Javascript 变量作用域 两个可能会被忽略的小特性_javascript技巧

也许有些高手早已知道了,但是我觉得这两个东西还是有一些价值的,所以拿到这里和大家分享一下吧. 有如下代码: 复制代码 代码如下: <script type="text/javascript" > function test() { with (location) { var temp = "an url"; } alert(temp); } test(); </script>     调用这个函数会输出什么呢? 也许会认为它会弹出undefi

javascript变量作用域使用中常见错误总结_javascript技巧

今天在rainweb的博客上,看到了这篇非常好的文章,觉得非常有必要分享出来,相信大家认真读完这篇文章,对js作用域的理解又会上升到一个新的台阶. 前言:javascript里变量作用域是个经常让人头痛抓狂的问题,下面通过10++个题目,对经常遇到又容易出错的情况进行了简单总结,代码样例很短很简单 题目一 复制代码 代码如下: var name = 'casper'; alert(name); //毫无疑问地输出:casper 题目二 复制代码 代码如下: alert(name); //报错:对

深入解析JavaScript中的变量作用域_javascript技巧

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

javascript 变量作用域 代码分析_javascript技巧

代码清单1-1 展示javascript的变量作用域的例子 //设置全局变量foo,并置为"test" var foo = "test"; //在if块中 if(true){ //将foo置为'new test' var foo = "new test"; } //如我们所见,现在foo等于'new test'了 alert(foo == "new test"); //创建一个会修改变量foo的新函数 function tes