let关键字

let关键字和var关键字一样,都是用来声明变量的,但是和var不同的是,let关键字声明的变量仅在自己的块级作用域范围内发挥作用。

我们来比较下面两段代码

var arr = new Array();
for(var i = 0; i < 10; i++){
arr[i] = function(){
console.log(i);
}
}
arr[0]();//10

上面一个程序中,我们本意是定义一个数组,每个数组的元素是一个函数,可以打印出数组的下标,但是无论调用数组中的哪一个函数,输出的都是10。

var arr = new Array();
for(let i = 0; i < 10; i++){
arr[i] = function(){
console.log(i);
}
}
arr[0]();//0

这个程序和上面一个程序的唯一的不同,就是在声明变量i时我们使用了let关键字而不是var关键字,然而我们得到了想要的结果。这是由于let关键字只能在自己的块级作用域中发挥作用,出了它的块级作用域就不再发挥作用了。(块级作用域,简单的来说就是用{}大括号包含的部分)

除了只能在块级作用域发挥作用外,let关键字还有另外的特点,第二点就是不存在变量提升,而var关键字存在变量提升。

function foo(){
console.log(a);
var a;
}
foo();

上面这个程序中,会打印出undefined,而使用let关键字,则会报错。

function foo(){
console.log(a);
let a;
}
foo();

这是由于var关键字的变量提升,变量提升可以理解为解释器在作用域内先寻找var关键字,将用var声明的变量先存储在内存中,然后再一步一步的执行代码。第一个实例相当于将var a;这一行代码放到console.log()这一行的上面。而let关键字不存在变量提升,因此在程序执行到console.log()时,在内存找不到a的地址,因此会报错。

除此之外,使用let关键字时要注意两个要点:

  1. 同一个块级作用域内不能重复声明同一个变量
var a = 0;
let a = 0;

上面这段程序会报错,同样,用两个let关键字声明同一个变量也是不允许的。

let a = 0;
let a = 0;

2.函数中不能用let关键字重新声明函数的参数。

function foo(a){
let a = 0;
console.log(a);
}

像这样是不允许的。

const关键字

const关键字时用来声明一个常量的,即不能修改的值。

const a = 0;
a = 1;

上面这种做法是错误的,它试图给常量a赋一个新值。

此外,const常量还有其他几个特点:

1.const关键字声明的常量不能修改

2.const关键字和let关键字一样,只能在自己的块级作用域内发挥作用

3.和let一样,不存在变量提升,而且和let不同的是,const关键字声明时必须赋值

4.和let一样,不能重复的声明同一个变量。

有了const关键字,我们还可以创建一个常量对象

const car = { "type" : "van" };
car.price = 30000;
car.type = "tractor";

我们会发现,这段程序不会报错,但是我们确实修改了car这个常量。这是因为,javascript中是使用传址赋值的方式,所谓的传址赋值,就是在赋值过程中,变量存储的实际上是数据的地址,即对数据的引用,而不是原始的数据或者数据的拷贝。我们在声明car变量时,分配了地址,增添或者修改car的属性不会改变它所在的地址,因此不会报错。而如果像下面这样

const car = {type:"van"};
car.type = "tractor";
car.price = 30000;
car = {};

这个程序试图给car赋一个新值{},则会报错。

ECMAScript6之let与const关键字的更多相关文章

  1. PHP的final关键字、static关键字、const关键字

    在PHP5中新增加了final关键字,它可以加载类或类中方法前.但不能使用final标识成员属性,虽然final有常量的意思,但在php中定义常量是使用define()函数来完成的. final关键字 ...

  2. C++中const关键字的使用总结

    C++中使用const关键字来修饰常量,下面从两个方面总结:变量和成员函数. 变量:const可以修饰普通变量.指针(数组)和结构体. 1.const修饰普通变量是最简单的情形.这样的用法多为在程序中 ...

  3. final关键字+const关键字

    final关键字 1.如果我们希望某个类不被其它的类来继承(可能因为安全考虑),可以使用final. 例题 <? final class A{} class B extends A{};//会报 ...

  4. C++学习11 类和new、delete操作符 类与const关键字

    如果你是Java.C#.PHP程序员,那么会对 new 非常熟悉,在这些编程语言中,只能通过 new 来创建对象. 在C++中,你可以像定义变量一样来创建对象,如: Student stu; //对象 ...

  5. C++中的const关键字

    http://blog.csdn.net/eric_jo/article/details/4138548 C++中的const关键字的用法非常灵活,而使用const将大大改善程序的健壮性,本人根据各方 ...

  6. 陈正冲老师讲c语言之const关键字

    1.const 关键字也许该被替换为 readolny const是constant的缩写,是恒定不变的意思,也翻译为常量.常数等.很不幸,正是因为这一点,很多人都认为被const修饰的值是常量.这是 ...

  7. C语言之头文件,static与const关键字

    [前言] 最近几个月在做一个C语言代码重构的项目,过程中也让我对之前在书本上学习到的东西有些补充和巩固,在本博中总结记录下,梳理下零碎的知识点和经验也加深印象,书写是为了更好地思考.平时也都是用印象笔 ...

  8. static和const关键字的作用

    static关键字至少有下列n个作用: (1)函数体内static变量的作用范围为该函数体,不同于auto变量,该变量的内存只被分配一次,因此其值在下次调用时仍维持上次的值: (2)在模块内的stat ...

  9. const关键字详解

    const在函数前与函数后的区别 一   const基础         如果const关键字不涉及到指针,我们很好理解,下面是涉及到指针的情况:         int   b   =   500; ...

随机推荐

  1. Csharp Syntactic sugar

    C#语法糖(Csharp Syntactic sugar)大汇总 首先需要声明的是“语法糖”这个词绝非贬义词,它可以给我带来方便,是一种便捷的写法,编译器会帮我们做转换:而且可以提高开发编码的效率,在 ...

  2. 状态机图statechart diagram

    [UML]UML系列——状态机图statechart diagram 系列文章 [UML]UML系列——用例图Use Case [UML]UML系列——用例图中的各种关系(include.extend ...

  3. 10-18 noip提高组模拟赛(codecomb)T2贪心

    T2:找min:一直找最小的那个,直到a[i]-x+1小于0,就找次小的,以此类推: 求max,也是一样的,一直到最大的那个,直到次大的比之前最大的大,就找次大的: 这个模拟,可以用上priority ...

  4. Activity的启动模式与flag详解

    Activity有四种加载模式:standard(默认), singleTop, singleTask和 singleInstance.以下逐一举例说明他们的区别: standard:Activity ...

  5. 从网络上获取图片并保存在sdCard上

    package com.aib.soft; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileO ...

  6. Task.WhileAll扩展方法

    TPL实现Task.WhileAll扩展方法 文章翻译整理自 Nikola Malovic 两篇博文: Task.WhileAll Awaitable task progress reporting ...

  7. django下载文件

    赶快记录一下写的一个django下载文件的例子,以便以后复习: 在views.py中设置 from django.core.servers.basehttp import FileWrapper im ...

  8. jQuery extend函数详解

    一 jQuery的扩展方法原型是 $.extend(dest,src1,src2,src3); 含义是将src1,src2,src3合并到dest中,返回值为合并后的dest,该方法合并后,dest的 ...

  9. EasyUI实现异步加载tree(整合Struts2)

    首先jsp页面有一ul用于展现Tree <ul id="mytree"></ul> 加载Tree <script type="text/ja ...

  10. 趋势:Chrome为打包应用提供强大新特性

    Chrome 7月9日刚为Chrome打包的应用提供了强大的访问Google服务例如Google统计.GoogleAPI和Google 钱包的能力,除此之外,还能够使用系统层面的服务包括蓝牙和原生应用 ...