博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ES6语法:let和const
阅读量:5299 次
发布时间:2019-06-14

本文共 1173 字,大约阅读时间需要 3 分钟。

ES6新增加了两个重要的JavaScript关键字:let和const

一、let关键字

let声明的变量只在let命令所在的代码块内有效。

1、基本语法

let a='123'

2、let和var的区别

 var也是用来声明变量,let和var有什么区别呢?区别主要是以下三点:

2.1、同一作用域内let不能重复定义同一个名称,var可以重复定义

看下面的例子:

// 同一个作用域内let不能重复定义同一个名称let a='123';let a='456'; // 错误// var可以重复定义var a=10;var a=20;

2.2、两者作用域不同

let属于块级作用域,只在当前块内有效。

var属于全局作用域。

看下面的示例:

        
ES6

效果:

打印str1的时候会报错,因为超出了str1的作用域。

2.3、不存在变量提升

var声明的变量存在变量提升,即可以在变量声明之前就使用该变量,值为undefined;而let不存在变量提升,必须先声明变量才能使用。看下面的例子:

        
ES6

 效果:

二、const

const与let的相同点:都是块级作用域。

不同点:const声明的是一个只读的常量,声明之后就不允许改变。意味着,声明的同时必须初始化。看下面的例子:

const pi='3.1415926';pi='3.1415927'

查看控制台结果:

声明的同时必须初始化,看示例:

        
ES6

控制台结果:

注意:

const 如何做到变量在声明初始化之后不允许改变的?其实 const 其实保证的不是变量的值不变,而是保证变量指向的内存地址所保存的数据不允许改动。此时,你可能已经想到,简单类型和复合类型保存值的方式是不同的。是的,对于简单类型(数值 number、字符串 string 、布尔值 boolean),值就保存在变量指向的那个内存地址,因此 const 声明的简单类型变量等同于常量。而复杂类型(对象 object,数组 array,函数 function),变量指向的内存地址其实是保存了一个指向实际数据的指针,所以 const 只能保证指针是固定的,至于指针指向的数据结构变不变就无法控制了,所以使用 const 声明复杂类型对象时要慎重。

        
ES6

控制台结果:

转载于:https://www.cnblogs.com/dotnet261010/p/10805516.html

你可能感兴趣的文章
SSL-ZYC 2645 线段树练习题二
查看>>
【算法题12 解码方法decode way】
查看>>
采用Operator-sdk轻松将helm chart转为Operator
查看>>
Sublime Text 3下安装MarkDown并实时预览
查看>>
NOIP2011 计算系数
查看>>
淘淘商城之创建工程
查看>>
2019-04-03 SQL Group By某列,预先对该列进行一个预处理,提炼出共有的信息,即关键字case when 列名什么条件 then 赋值 else 赋值 end as 新列名...
查看>>
JAVASCRIPT和JQUERY判断浏览器信息总汇(备忘)
查看>>
2015上半年阅读书籍
查看>>
内存映射与访问机制
查看>>
HTML的学习
查看>>
json格式tomcat access_log导入mysql库
查看>>
jquery 条形码 插件jquery-barcode使用
查看>>
垃圾收集-分代划分
查看>>
【UVA11478】Halum (最短路解差分约束)
查看>>
spring与quart整合实现任务调度_学习笔记
查看>>
html快捷编辑
查看>>
Python 闭包小记
查看>>
HDU4784 Dinner Coming Soon(dp)
查看>>
重构机房收费系统你要用的——异常处理和抛出异常(try catch finally)——(vb.net)...
查看>>