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"
}
上一篇:python迭代器和生成器


下一篇:【C++ Primer | 15】继承的构造函数