javascript中var let const三种变量声明方式

Posted 云水

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript中var let const三种变量声明方式相关的知识,希望对你有一定的参考价值。

javascript中var let const三种变量声明方式

 

1、var 

 

①var表示声明了一个变量,并且可以同时初始化该变量。

 

②使用var语句声明的变量的作用域是当前执行位置的上下文:一个函数的内部(声明在函数内)或者全局(声明在函数外)。

 

③给一个非声明变量赋值会隐式创建一个全局变量(造成代码污染)(全局object的一个属性)。声明变量(Declared Variable)和非声明变量(Undeclared Variable)的区别是:

(1)声明变量的作用域限制在其声明位置的上下文中,而非声明变量总是全局的。

(2)声明变量在任何代码执行前创建,而非声明变量只有在执行赋值操作的时候才会被创建。

(3)声明变量是它所在上下文环境的不可配置属性(non-configurable property),非声明变量是可配置的(例如非声明变量可以被删除)。

强烈建议必须使用声明变量!!!(无论是否在函数内)

 

④变量提升:由于变量声明(以及其他声明)总是在任意代码执行之前处理的,所以在代码中的任意位置声明变量总是等效于在代码开头声明。这意味着变量可以在声明之前使用。

 

2、let

 

①let声明了一个块级域的局部变量,并且可以给它一个初始化值。

 

let 允许把变量的作用域限制在块级域中。与var不同处是:var 申明变量要么是全局的,要么是函数级的,而无法是块级的。

 

③let声明的变量作用域包含定义它的块以及任何包含的子块中。这点与var相似。

 

为什么会是let这个名字?https://stackoverflow.com/questions/37916940/js-why-let-have-this-name

 

⑤在程序或者函数的顶层,let 与 var 表现相似。

 

⑥在同一个函数或同一个作用域中用let重复定义一个变量将引起TypeError。

 

⑦let的作用域是,而var的作用域是函数

 

let块提供了一种在块的范围内获取变量的值,而不会影响块外面名字相同的变量的值的方法。

 

 

3、const

 

①const 声明创建一个只读的常量。这不意味着常量指向的值不可变,而是变量标识符的值只能赋值一次。(注意区分常量的值和常量指向的值的不同)

注:这点与Java C++中类似。即:指向常量的指针,表示这个指针不能改变所指向变量的值,仅表示“只读“。但是被指向的变量的值可以通过其他手段改变。

 

②可以在全局作用域或者函数内声明常量,常量需要被初始化

 

③常量拥有块作用域,和使用let定义的变量十分相似。常量的值不能通过再赋值改变,也不能再次声明。

 

④一个常量不能和它所在相同作用域内的其他变量或函数拥有相同的名称

 

⑤常量可以是一个具体的值,也可以是一个对象。注意:常量是对象时,对象内部的属性可变而不受保护。

例如:

const myObject = {"key":"value"};

myObject = {"newKey":"newValue"}; // 这句报错

myObject.key = "newValue"; // 这句则会成功

 

以上是关于javascript中var let const三种变量声明方式的主要内容,如果未能解决你的问题,请参考以下文章

javascript精雕细琢:var let const function声明的区别

ES6新语法(let和const)

JavaScript中声明变量var和let/const的区别讲解

Javascript 对象解构赋值是不是使用 const、let 或 var?

ES6语法:let和const

Javascript var/let/const 变量初始化