javascript基础知识-命名提前,作用域

javascript的代码存在命名提前的现象,在这里结合javascript的特殊作用域来解释。

一般很多后台语言,比如C#都是块级作用域,也就是花括号范围内定义的变量,作用域被限制在花括号以内。

而javascript则是函数级作用域,也就是说在函数体内定义的变量,拥有在函数内的作用域。

比如下面的例子:

function test(o){
    var i = 0;                                    //i在整个函数体内均有定义
    if(typeof o == "object"){
        var j = 0;                                //j在整个函数体内是有定义的,不仅仅是这个代码段内
        for(var k = 0;k<10;k++){
            console.log(k);                   //k在函数体内是有定义的,不仅仅实在循环内
        }
        console.log(k);                       //输出0~9
    }
    console.log(j);                            //j已经定义了,但可能没有初始化
}    

这里存在一个问题,倒数第二行的console(j)中的j为什么可能没有初始化呢?

因为根据传入的参数o,j有可能被初始化,有可能不被初始化,比如test({}),就会被初始化,而test(99)则不会进入if语句块。

这里要注意,函数的初始化还是留在原来的位置的,知识命名提前了。

另外今天还学到一个知识点

javascript里声明的所有变量(但不涉及赋值)都被"提前"值函数体顶部,重点是赋值不会提前!

var scope = "global";
function f(){
  console.log(scope);  //输出undefined
  var scope = "local";  
  console.log(scope);  输出"local"
}
原文地址:https://www.cnblogs.com/zjtTT/p/4993252.html