let var 和const声明变量,之间的区别是什么

let 和 const 是es6 新出来的语法

1,let 是块级作用域,函数内部使用let 定义后,对函数外部无影响,如果不初始化输出的话,会报语法错误

1 let c = 3;
2 console.log(‘函数外let定义c:‘ + c);//输出c=3
3 function change(){
4 let c = 6;
5 console.log(‘函数内let定义c:‘ + c);//输出c=6
6 }
7 change();
8 console.log(‘函数调用后let定义c不受函数内部定义影响:‘ + c);//输出c=3

2,const 是全局作用域,const 声明的变量,不可以直接修改,必须初始化,const 一般用在数组的定义和修改中

1 const b = 2;//正确
2 // const b;//错误,必须初始化
3 console.log(‘函数外const定义b:‘ + b);//有输出值
4 // b = 5;
5 // console.log(‘函数外修改const定义b:‘ + b);//无法输出

3,var 全局变量,声明的变量可以修改,如果不初始化输出的话,会报undefined,但不会报错

1 var a = 1;
2 // var a;//不会报错
3 console.log(‘函数外var定义a:‘ + a);//可以输出a=1
4 function change(){
5 a = 4;
6 console.log(‘函数内var定义a:‘ + a);//可以输出a=4
7 }
8 change();
9 console.log(‘函数调用后var定义a为函数内部修改值:‘ + a);//可以输出a=4

原文地址:https://www.cnblogs.com/jj9219/p/9197836.html

时间: 2024-10-07 20:58:36

let var 和const声明变量,之间的区别是什么的相关文章

var,let,const声明变量?

var 与 let 的区别? 1.var支持变量预检测,let不支持 console.log(a); // undefined 程序不会报错 var a = 1; console.log(b); //程序报错 b is not defined let b = 2; 2.let 不支持重复声明 var a = 1; var a = 10; console.log(a); // 10 let b = 2; let b = 200; console.log(b); //程序报错 Identifier

关于react const声明变量引用this.state,然后setState不刷新问题

mdzz..const声明的变量保持原引用. this.setState会发现引用没有改变更改内部属性不会触发更新. let picList: any = this.state.resumeImages; picList = JSON.parse(JSON.stringify(picList)) if (picList[index]) { picList[index].src = key; } else { picList.push({ src: key }) } this.setState({

在全局下用let声明变量和用var声明变量还是有区别的

sleep方法的作用是让当前线程暂停指定的时间(毫秒),sleep方法是最简单的方法,在上述的例子中也用到过,比较容易理解.唯一需要注意的是其与wait方法的区别.最简单的区别是,wait方法依赖于同步,而sleep方法可以直接调用.而更深层次的区别在于sleep方法只是暂时让出CPU的执行权,并不释放锁.而wait方法则需要释放锁. 最近两天在系统的复习性能测试方面的知识,结合之前的性能测试经验有了一些总结,希望写出来与大家分享,希望多提宝贵意见,共同进步~首先来说说性能测试:性能是软件的一种

为什么JavaScript声明变量的时候鼓励加var关键字

在JavaScript中,var用来声明变量,但是这个语法并不严格要求,很多时修改,我们可以直接使用一个变量而不用var声明它. [javascript] view plaincopyprint? var x = "XX"; y ="xxx"; var x = "XX"; y ="xxx"; 诸如此类.这有一个问题,比如说在代码中的某一行,我想使用的一个已声明的变量x,结果由于打字或者拼写错误,这个变量被写成y了,结果相当于“

var、const、let 的区别

定义变量的三种方式 var.const.let 都可以用来定义变量,但三者之间存在区别. var var 声明变量的时候无需初始化. var 声明的变量可在后面进行修改. var 声明的全局变量可以被函数修改. <!DOCTYPE html> <html> <head> <title></title> </head> <body> <script type="text/javascript">

var/let/const区别何在??

原文地址:http://www.cnblogs.com/liuhe688/p/5845561.html let和const有很多相似之处,先说一说let吧. 1. let添加了块级作用域 我们知道,JavaScript是没有块级作用域的,如果在块内使用var声明一个变量,它在代码块外面仍旧是可见的: if (true) { var foo = 3; } console.log(foo); // 3 for (var i = 0; i < 9; i++) { var j = i; } consol

es6 - 一共有 6 种声明变量的方法(var, function, let, const, class, import)

let声明的变量只在它所在的代码块有效. 不存在变量提升 let不允许在相同作用域内,重复声明同一个变量 暂时性死区,只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域,不再受外部的影响, 定义之前不能使用. 应该避免在块级作用域内声明函数.如果确实需要,也应该写成函数表达式,而不是函数声明语句. for循环的计数器,就很合适使用let命令. for (let i = 0; i < 10; i++) {let i = 'abc';} // 变量i是let声明的,当

ES6和ES5变量声明的区别(var let const)

// es5的语法与es6的语法区别 // var let const console.log(name);//undefine,不会报错,因为变量声明会提到作用域的最前面 var name="aa"; for(var i=1;i<7;i++){ console.log(i); } console.log(i);//8,不会报错因为var声明的变量没有块级作用域 /** * 总结 var 声明的变量,声明语句会提到作用域的最前面,并且没有块级作用域 */ console.log(

2-新的变量声明方式(var ,let,const)

以前我们在声明时只有一种方法,就是使用var来进行声明,ES6对声明的进行了扩展,现在可以有三种声明方式了. 字面理解ES6的三种声明方式: var:它是variable的简写,可以理解成变量的意思. let:它在英文中是“让”的意思,也可以理解为一种声明的意思. const:它在英文中也是常量的意思,在ES6也是用来声明常量的,常量你可以简单理解为不变的量 --var声明---- var在ES6里是用来升级全局变量的,我们可以先作一个最简单的实例,用var声明一个变量a,然后用console.