JavaScript变量声明

const,let,var的区别和用法spa

1.const——声明一个只读的常量,在声明的时候给其赋初值,以后不能再进行赋值。code

1 const i = 0;
2 console.log(i);    //有输出,为0

若是对 i 进行再次赋值则会报错,TypeError:Assignment to constant variableblog

1 const i = 0;
2 i = 5;
3 console.log(i);    //无输出,报错

2.var——用于声明变量,声明在方法外则为全局变量,在方法内则为局部变量,只能在方法内读取。作用域

1 var i;
2 console.log(i);    //若是不赋初值,输出为undefined

若是声明变量时没有使用 var 关键字,则该变量必定为全局变量。到那时在调用的时候有如下区别:io

若是时声明在方法外的全局变量,在方法内能够直接使用;若是该全局变量时声明在方法内部的,则在方法外使用该变量时须要先调用方法,告知系统声明了全局变量才能使用。console

须要特别注意的问题:没有使用 var 关键字定义的全局变量没有预编译过程,因此若是把变量的使用放在定义以前则会报错。编译

1 alter(i);  //  i is not defined    
2 i = 1;

3.let——块级做用域,方法内部使用 let 定义后对方法外没有影响。function

let 时ES6新增的变量声明命令,做用就是声明一个局部变量。class

1 var a = [];
2 for(var i=0;i < 10;i++){
3 //循环内的计数变量 i 使用var定义为全局变量,因此循环过程当中会不断地对值进行覆盖
4    a[i] = function (){
5       console.log(i);
6    }  
7 }
8 a[6]();    //最后的输出是 10
var a = [];
for(let i=0;i < 10;i++){
//这里的 i 使用let定义为局部变量,就是只在当前循环生效,因此每次进行循环的 i 都是新的变量,值不会进行覆盖
    a[i] = function(){
        console.log(i);
    }
}
a[6]();  //最后的输出是 6 
相关文章
相关标签/搜索