var let const 都是来定义变量的. var let 作用域有些区别. const 类似于java中的常量的概念.即:只能给一个变量赋值一次,即指定一个引用. 举例来说: function test(){ var i=1; console.log(i); console.log(j); var j=2; } test(); console.log(i); 可以预计第一个输出 1 ,第二个输出 undefined,第三个输出0: 如果用let 取代 var function test()…
简述: 1.前端的变量申明,可以用到var,ES6的const(衡量)/let(变量) 2.在ES5用的都是var,到ES6之后,也就是2015年开始出现const/let. var 不会报错,有声明提升,会显示undefined(一个变量未初始化): function show(falg){ // var a;//**声明提升,初始化为undefined,函数体(作用域)的最前排 console.log(a);//undefined if(falg){ var a ="111"; c…
1.var var 声明的变量为全局变量,并会进行变量提升:也可以只声明变量而不进行赋值,输出为undefined,以下写法都是合法的. var a var a = 123 2.let let 声明的变量为局部变量,用于块级作用域,使用前必须进行先声明:不会进行变量提升:声明变量以后不能够在同一作用域进行重复声明变量,会报错. 3.const const 声明变量的要求在 let 基础上增加,声明的的变量值不能够变更,所以要求使用前必须声明并赋值,否则会报错. 总结: var > let >…
先看let和var: 1. console.log(a); // undefined var a = 3; console.log(a); // Uncaught ReferenceError: Cannot access 'a' before initialization let a = 3; 在当前代码执行之前,首先会把所有带var关键字的进行声明(带function关键字的也会提前声明并且定义),即所谓的变量提升,let则不存在这种情况. ps:项目中创建函数,一般都是基于函数表达式来…
JavaScript var, let, const difference All In One js var, let, const 区别 All In One 是否存在 hoisting var 存在 hoisting; let, const 不存在 hoisting; let, const 存在 TDZ 暂时死区,在定义之前,不可以访问 const log = console.log; log(`i =`, i); // Uncaught ReferenceError: i is not…
js var & let & const All In One js var & let & const 区别对比 var let const 区别 是否存在 hoisting / 变量提升 var 存在 hoisting; let, const 不存在 hoisting; 作用域范围 var 是全局 scope 或函数 scope; let, const 是 block scope / 块级作用域; 能否重复声明 var 可以重复声明; let, const 不可以重复声…
Learn-JavaScript-with-MDN 系列文章: 01. var & let & const 对比 var & let & const 区别 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/var https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let…
1.变量声明--var,const,let 1.1 var - (全局作用域,局部作用域)会有变量提升 //第一个小例子 <script> var num = 123; function fn(){ console.log(num); // undefined var num = 46; console.log(num) // 46 } fn() </script> //为什么第一个输出值会是undefined,而不是123呢?因为这里存在着变量名的提升,其实上述语句相当于: &l…