javaScript中使用var和不是用var定義變量的區別

分類:技術 時間:2017-01-20

javaScript與java、c語言雖然有很多相同,但是也存在區別

JavaScript的變量沒有塊範圍

(1)看下面的例子

<script type="text/javascript">
    //定義全局變量
    var scope="全集變量";
    function test(){
        //全局變量被局部變量覆蓋
        document.writeln(scope+"<br/>")
        //定義scope局部變量,起作用範圍是整個函數
        var scope="局部變量";
        //再次輸出scope值
        document.writeln(scope);
    }
    test();
</script>

運行結果:

itread01

(2)去掉test()中的var

<script type="text/javascript">
    //定義全局變量
    var scope="全集變量";
    function test(){
        //全局變量被局部變量覆蓋
        document.writeln(scope+"<br/>")
        //定義scope局部變量,起作用範圍是整個函數
        scope="局部變量";
        //再次輸出scope值
        document.writeln(scope);
    }
    test();
</script>

運行結果:

itread01

(3)原因分析

主要是定義變量用var和不用var確實存在差異:

①如果使用var變量,那麽程序會強制定義一個新變量

②如果沒有使用var定義變量,系統會優先在當前上下文中搜索是否存在該變量,只有在該變量不存在的前提下,系統才會重新定義一個新變量

上面之所以從 undefined變成“全局變量”,是因為定義局部變量的代碼處不是定義新變量,而是直接建全局變量scope賦值。因此test()並沒有覆蓋全局變量scope,故也就輸出“全局變量”


Tags: javascript js

文章來源:


ads
ads

相關文章
ads

相關文章

ad