1、如果在全局作用域中用var声明变量,此变量会默认成为window的一个属性,let声明的变量则不会添加到window对象中。
2、在es6之前,是没有块级作用域,所谓块级作用域,就是用{}包含的区域,我们常用的有for,while,if等。但是在块级作用域中用let声明变量,那么此变量就有了块级作用域,就必须只有在此块级作用域才能访问此变量。
3、var声明的变量有变量提升特性,let声明则没有这个特性。变量提升:请点击:javascript中的变量提升的简单芹亮说明。
4、var可以允许重复声明相同的变量,后者会覆盖前者,let则不能重复声明相同的变量。
而常量更普通的意义在于它不是变量。不同的系统约定也不一样。es5之后又细分出了let(变量)const(常量)这两种类型。但是const的出现也表示js脚本开始走向类如java,c#那种重型语言的编写方式,明确细分了常量和变量。
let对比var都是变量(var没有变量常量一说,但ES5之后其行为与let类似),但是,var和let有很大区别,简单理解就是作用域变了,使用变量需要先声明在赋值后使用的流程。
let继承了这种流程,而var没有,在代码里的体现就是,let只在定义它的上一个大括号内及其所有子方法体起作用,比如方法中定义let则出了这个方法就没法使用到这个let,同级别的两个方法,可以各自定义一个同名let变量。
变量
是程序中数据的临时存放场所。在代码中可以禅旁只使用一个变量,也可以使用多个变量,变量中可以存放逗毁单词、数值、日期以及属性。由于变量让你能够把程序中准备使用的每一段数据都赋给一个简短、易于记忆的名字,因此它们十分有用。
变量可以保存程序运行时用户输入的数据(如使用InputBox函数在屏幕上显示一个对话框,然后把用户键入的文本保存到变量中)、特定运算的结果以及要在窗体上显示的一段数据等。简而言之,变量山袭备是用于跟踪几乎所有类型信息的简单工具。
ES6新增了let命令,用来声明变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效。
使用 let 语句声明一个变量,该变量的范围限于声明它的块中。肢昌 可以在声明变量时为变量赋值,也毕李可以稍后在历数扒脚本中给变量赋值。
使用 let 声明的变量,在声明前无法使用,否则将会导致错误。
如果未在 let 语句中初始化您的变量,则将自动为其分配 JavaScript 值 undefined。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)