let和var声明变量的区别:1.let所声明的变量只在let命令所在的代码块内有效.(块级作用域) for(let i=0;i<10;i++){ // ... } console.log(i); // ReferenceError: i is not defined当前的i只在for循环中有效,当在全局环境中去寻找时是找不到的,所以程序报错 var a = []; for (var i = 0; i < 10; i++) { a[i] = function () { console.log(
ES6 中除了使用 var 定义变量,还有let.const,定义变量. function getValue(condition){ console.log(typeof value2); // undefined,与 if 语句中的 value2 不在同一个作用域中 //console.log(typeof v); //临时死区,需要先定义后使用,ReferenceError: v is not defined let v = "e"; let value1; // let valu
学习JS时候,声明变量是必须的,(虽然在没有声明变量的情况下,对某一变量赋值后, js自动认为已进行声明,但为了严谨,建议还是要进行声明)声明方式有传统的 var a: var b: var c: 也有精简的 ==>var a,b,c: 当需要声明变量且进行赋值时,可以这样 ==>var a =1 :var b = 2 var c: 等价于var a=1,b = 2,c: 注意事项: 1.单独声明时候,虽然“:”不写也没关系,但是为了后面的编程,建议养成每一句结束都带上“:”(分号<英&
1.变量声明: 在非严格模式下,函数可以对未声明的变量赋值,而这样赋值的结果就是该变量就会变成全局变量. (function(){ var a = 1; })(); console.log(a) ; 上面的代码原意是在一个立即执行的匿名函数内声明一个函数内部变量,不过没有加 var js引擎默认为变量a赋值.所以现在函数内部查找变量名a,显然不存在便向上级作用域查找,此处的上级作用域是window,既全局作用域.全局作用域中也不存在a变量,便在全局中声明变量a,并赋值. 上图显示了加 var后的
function aa(flag) { // var test // 变量提升,函数最顶部 if(flag) { var test = 'hello man' } else { //此处访问 test 值为 undefined console.log(test) } //此处访问 test 值为 undefined } aa(false); //结果 undefined test被声明了 但是没有被赋值 总结: 用var声明变量时,变量提升到函数最顶部或全局最顶部. function aa(fl