美文网首页
js中const,var,let区别

js中const,var,let区别

作者: 夏天的技术博客 | 来源:发表于2020-04-07 10:12 被阅读0次

在javascript中有三种声明变量的方式:var let const
let var const的区别?
var
由于变量声明(以及其他声明)总是在任意代码执行之前处理的,所以在代码中的任意位置声明变量总是等效于在代码开头声明。这意味着变量可以在声明之前使用,这个行为叫做“hoisting”。“hoisting”就像是把所有的变量声明移动到函数或者全 局代码的开头位置。

bla = 2
var bla;
// ...
// 可以理解为:   
var bla;  
bla = 2; 由于这个原因,我们建议总是在作用域的最开始(函数或者全局代码的开头)声明变 量。这样可以使变量的作用域变得清晰。

let
注意:必须声明'use strict';后才能使用let声明变量否则浏览并不能显示结果。
let作用域:只在let命令所在的代码块内({})有效

//let声明 的变量只在它所在的代码块有效。
{let a=3;} 
console.log(a);//VM11918:1 Uncaught ReferenceError: a is not defined

//计数器i只在for循环体内有效,在循环体外引用就会报错
for (let i = 0; i < 3; i++) {}
console.log(i);//VM13498:1 Uncaught ReferenceError: i is not defined

//for循环还有一个特别之处,就是循环语句部分是一个父作用域,而循环体内部 是一个单独的子作用域。
for (let i = 0; i < 3; i++) {
  let i = 'abc';
  console.log(i);
}

const
1、const声明一个只读的常量。一旦声明,常量的值就不能改变。

const PI = 3.1415;
PI=3;//VM33690:1 Uncaught TypeError: Assignment to constant variable.

2、const声明的变量不得改变值,这意味着,const一旦声明变量,就必须立即初始化,不能留到以后赋值。

const foo;//VM35236:1 Uncaught SyntaxError: Missing initializer in const declaration

3、const的作用域与let命令相同:只在声明所在的块级作用域内有效。

区别:
1、var可以先使用,后声明;let必须先声明后使用。

image

2、暂时性死区:只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域, 不再受外部的影响。

image

3、var是允许在相同作用域内重复声明同一个变量的,而let与const不允许这一现象。

image

作者:爱笑的疯小妞
链接:https://www.jianshu.com/p/e93b0b833eba
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关文章

  • js 2022经典面试题汇总

    1.JS数据类型有哪些 2.var、let、const区别 var存在变量提升,而let、const没有 let、...

  • Android菜鸟学习js笔记 一

    一、var,const,let区别? var 变量,const 常量,let块级变量。

  • JS中var、let、const区别

    在javascript中有三种声明变量的方式:var let const。let var const的区别?var...

  • js中let、var、const区别

    块级作用域绑定的let const 为JavaScript引入了词法作用域,它们声明的变量不会提升,而且只可以在声...

  • js中const,var,let区别

    今天第一次遇到const定义的变量,查阅了相关资料整理了这篇文章。主要内容是:js中三种定义变量的方式const,...

  • js中const,var,let区别

    在javascript中有三种声明变量的方式:var let const。let var const的区别?var...

  • js中 var let const 区别

    var 1.仅仅声明 默认值是 undefined 2.可以重新赋值 3.作用域是方法内 ,而不是代码块内 let...

  • sample

    一、var与let JS中的块级作用域,var、let、const三者的区别 var是函数级作用域,没有块级作用域...

  • es6

    1、let 和const(定义变量) (1)var 、let 、const的区别 a、作用域区别var 变量声明会...

  • js var 、let 、const区别

    1、var定义的变量可以修改。不用多说了(地球人都知道) 2、let是块级作用域,函数内部使用let定义后,对函数...

网友评论

      本文标题:js中const,var,let区别

      本文链接:https://www.haomeiwen.com/subject/volgphtx.html