ES6语法:var、let、const的区别详解
今天来说说es6的语法,最基础的也就是var,let,const 的用法与区别了,我们来看看他们之间的恩怨情仇。 首先来说说var,这个只要是学过js的都知道,它是用来声明一个变量的,但是它在开发中也会遇到一些问题,比较难解决。先来看看下面的代码: var str="hello world"; function testVar(){ var str="hello"; } testVar(); console.log(str); 这段代码的结果是 "hello world",这说明在var 申明的变量,即使是同样的名字,在不同的块中,在外层块中的变量优先级更高,也就是说,在外层优先使用并且只能使用当前块中的变量;而在他的内部块中的变量,比如说这个函数里面的str,他其实也是优先使用块内的str变量,会屏蔽掉外面的str变量,这是一点。再来看看下面一段代码 function variableHoisting(){ if(condition){ var test="hello javaScript"; }else{ console.log(test) //这里可以访问到test,但是它是undefined,因为初始化为它赋值成了undefined } //这里也可以访问到test } 可能你会感到奇怪,我的var 申明的变量在if