ECMAScript6之let与const关键字
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关键字时要注意两个要点:
- 同一个块级作用域内不能重复声明同一个变量
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关键字的更多相关文章
- PHP的final关键字、static关键字、const关键字
在PHP5中新增加了final关键字,它可以加载类或类中方法前.但不能使用final标识成员属性,虽然final有常量的意思,但在php中定义常量是使用define()函数来完成的. final关键字 ...
- C++中const关键字的使用总结
C++中使用const关键字来修饰常量,下面从两个方面总结:变量和成员函数. 变量:const可以修饰普通变量.指针(数组)和结构体. 1.const修饰普通变量是最简单的情形.这样的用法多为在程序中 ...
- final关键字+const关键字
final关键字 1.如果我们希望某个类不被其它的类来继承(可能因为安全考虑),可以使用final. 例题 <? final class A{} class B extends A{};//会报 ...
- C++学习11 类和new、delete操作符 类与const关键字
如果你是Java.C#.PHP程序员,那么会对 new 非常熟悉,在这些编程语言中,只能通过 new 来创建对象. 在C++中,你可以像定义变量一样来创建对象,如: Student stu; //对象 ...
- C++中的const关键字
http://blog.csdn.net/eric_jo/article/details/4138548 C++中的const关键字的用法非常灵活,而使用const将大大改善程序的健壮性,本人根据各方 ...
- 陈正冲老师讲c语言之const关键字
1.const 关键字也许该被替换为 readolny const是constant的缩写,是恒定不变的意思,也翻译为常量.常数等.很不幸,正是因为这一点,很多人都认为被const修饰的值是常量.这是 ...
- C语言之头文件,static与const关键字
[前言] 最近几个月在做一个C语言代码重构的项目,过程中也让我对之前在书本上学习到的东西有些补充和巩固,在本博中总结记录下,梳理下零碎的知识点和经验也加深印象,书写是为了更好地思考.平时也都是用印象笔 ...
- static和const关键字的作用
static关键字至少有下列n个作用: (1)函数体内static变量的作用范围为该函数体,不同于auto变量,该变量的内存只被分配一次,因此其值在下次调用时仍维持上次的值: (2)在模块内的stat ...
- const关键字详解
const在函数前与函数后的区别 一 const基础 如果const关键字不涉及到指针,我们很好理解,下面是涉及到指针的情况: int b = 500; ...
随机推荐
- 重温HTML的基础
新年新气象,新的一年要有自己的学习计划与工作计划.希望大家能够共享. 经过一段时间,我想重新复习与学习一下HTML的基础,我呢打算整理一下W3C里面的知识,也许对某些人没有任何作用,但是对我来说这是我 ...
- c#中解决winform中控件不能输入汉字的办法
设置控件的ImeMode属性 如: textBox.ImeMode = System.Windows.Forms.ImeMode.On; 其中枚举有如下值:
- 迟到的 WPF 学习 —— 路由事件
1. 理解路由事件:WPF 通过事件路由(event routing)概念增强了传统的事件执行的能力和范围,允许源自某个元素的事件由另一个元素引发,例如,事件路由允许工具栏上的一个按钮点击的事件在被代 ...
- ios7学习之路七(隐藏虚拟键盘,解决键盘挡住UITextField问题)
再正式开始之前,先来介绍一下IOS的键盘类型: 一.键盘风格 UIKit框架支持8种风格键盘 typedef enum { UIKeyboardTypeDefault, // 默认键盘:支持所有字符 ...
- 实现Launcher编辑模式(1) 壁纸更换
Android Launcher分析和修改13——实现Launcher编辑模式(1) 壁纸更换 Posted on 2013-09-11 23:25 泡泡糖 阅读(212) 评论(3) 编辑 收藏 已 ...
- jQuery图片切换插件jquery.cycle.js
Cycle是一个很棒的jQuery图片切换插件,提供了非常好的功能来帮助大家更简单的使用插件的幻灯功能 下载cycle插件并引入,此时,注意把引入它的代码放在引入jQuery主文件之后. <he ...
- NHIBERNATE的简单框架的设计
NHIBERNATE的简单框架的设计 上次的 NHibernate的Session管理策略和NHibernateHelper 发布并提供下载,给NHibernate刚入门的同学们带来很多便利. 最近有 ...
- MongoDB的一些用法(转藏)
MongoDB是目前工作中经常使用到的NoSQL数据库. 本博客只记录相关理论知识和技巧,涉及到实践的部分都会单开Blog来记录实践过程. ------------------------------ ...
- 关于Ajax无刷新分页技术的一些研究 c#
关于Ajax无刷新分页技术的一些研究 c# 小弟新手,求大神有更好的解决方案,指教下~ 以前做项目,用过GridView的刷新分页,也用过EasyUI的封装好的分页技术,最近在老项目的基础上加新功能, ...
- offsetWidth, offsetHeight, offsetLeft, offsetTop,clientWidth, clientHeight,clientX,pageX,screenX
offsetWidth: 元素在水平方向上占用的空间大小.包括元素的宽度,内边距,(可见的)垂直滚动条的宽度,左右边框的宽度. offsetHeight:元素在垂直方向上占用的空间大小,包括元素的高度 ...