1.let命令总结
1.let用法类似于var,但是let只在所在代码块有效
{
   let a = 10;
   var b = 1;
}
a     // ReferenceError: a is not defined.
b     // 1
2.let适用于for循环
for (let i = 0; i < 10; i++) {
   //...
}
console.log(i)  //ReferenceError: i is not defined
3.let 与 var 的区别
//***** let*****
var a = []
// 每一次循环,i都是新的变量,只在本轮循环有效
for (let i = 0; i < 10; i++) {
a[i] = function () {
console.log(i)
}
}
a[6](); // 6 //*****var*****
var a = []
// 变量i是var声明的,全局有效,每一次循环,i都会发生变化,里面所有的i都指向同一个i
for (var i = 0; i < 10; i++) {
a[i] = function () {
console.log(i)
}
}
a[6](); // 10
那么问题来了,使用let声明的i,在for循环条件中,每一次循环都是新的i,那么i如何记住上一次循环的值,来进行++,再到下一轮循环呢?答案是因为JavaScript引擎内部会记住上一轮循环的值,初始化本轮的变量i时,就在上一轮循环的基础上进行计算。
4.for循环的父子作用域
for (let i = 0; i < 3; i++) {
   let i = 'abc';
   console.log (i)
}
// abc
// abc
// abc
可以看出循环变量i与函数内部变量i不在同一作用域
5.“变量提升”概念
意思就是,一直以来var命令都会发生‘变量提升’的现象,意思就是变量可以在声明之前使用,输出的是“undefined”
6.let纠正了var的尴尬之处
// var 尴尬的地方,使用未声明的变量,竟然不报错
console.log(foo); //输出undefined
var foo = 2; // let纠正了var 的这一现象,使用未声明的变量,报错
console.log(bar); //输出ReferenceError
let bar = 2;
7.暂时性死区 (TDZ)
意思是,只要块级作用域{}存在let,用它来声明的变量,就不会受外部影响
var tmp = 123;
if (true) {
   tmp = 'abc';   //ReferenceError
   let tmp;// TDZ结束
   console.log(tmp)  // undefined
}
首先在{}中,存在let声明的tmp,那么tmp不受{}以外的变量影响,又因为在if里面的第一句使用到了tmp,这个东西又没有声明,看到总结的第5点就知道,它会报错。
所以,在let命令声明变量tmp之前,都属于变量tmp的死区!!
8.对死区使用 typeof 操作符
typeof x; // ReferenceError
let x; // 然而,对一个不存在的变量使用typeof,却不报错
type of undeclared_var // "undefined"
所以,在没有let之前,typeof运算符是百分之百安全的,永远不会报错
9.let不允许重复再相同作用域内,重复声明同一个变量
// 报错
function func () {
let a = 10;
var a = 1;
} // 报错
function func () {
let a = 10;
let a = 1;
} // 报错
function func (arg) {
let arg;
} // 不报错
function func (arg) {
{
let arg;
}
}
10. 使用let代替立即执行匿名函数
// 一般立即执行匿名函数是这样的
var config = (function() {
var config = []
config.push(1)
config.push(2)
config.push(3)
return config
}) // 使用let
let config;
{
config = []
config.push(1)
config.push(2)
config.push(3)
}
11.es6函数不被提升
一般使用‘use strict’开头,即严格模式,就是ES6
'use strict'
function a () {
console.log(1)
}
function f () {
a()
if (false) {
function a () {
console.log(2)
}
}
} f(); // 输出1
假如去掉严格模式语句,也就是老版本ES5状态下,是会输出2的,原因就是发生了函数的变量提升,即
function a () {
   console.log(1)
}
function f () {
   function a () {       // function a() 被提升到最前面了,即使if语句不执行
         console.log(2)
   }
   a()
   if (false) {
      function a () {
         console.log(2)
     }
   }
}
f();
// 输出2
12. const使用,物理内存地址不可更改
例如:
const a = {
   name = 'guang'
};
a.name = 'lighter';
a.email = '123456789@qq.com'
console.log(a);
// 输出为: { name : 'lighter', email : '123456789@qq.com' }
上面代码不会报错,这是为什么呢?因为这个const为复合型变量,变量名不知想数据,而是指向数据所在的地址。const命令知识保证变量名指向的地址不变,而不保证该地址的数据不变,所以将一个对象生命为常量必须非常小心
const的使用可以参照:http://www.cnblogs.com/zczhangcui/p/6393304.html
对于const常量,例如:const a = 13,因为13这个物理位置是不可变的,所有不能更改a指向的地址。
假如想测定不让修改const 对象,不管它是否复合型变量,都不允许更改
Object.freeze(a);
a.name = ' ' //报错
console.log(s)
------完------
1.let命令总结的更多相关文章
- Cmder--Windows下命令行利器
		cmder cmder是一个增强型命令行工具,不仅可以使用windows下的所有命令,更爽的是可以使用linux的命令,shell命令. 安装包 安装包链接 下载后,直接解压即用. 修改命令提示符λ为 ... 
- 【每日一linux命令4】常用参数:
		下面所列的是常见的参数(选项)义: --help,-h 显示帮助信息 --version,-V ... 
- .NET Core系列 : 1、.NET Core 环境搭建和命令行CLI入门
		2016年6月27日.NET Core & ASP.NET Core 1.0在Redhat峰会上正式发布,社区里涌现了很多文章,我也计划写个系列文章,原因是.NET Core的入门门槛相当高, ... 
- MVVM模式解析和在WPF中的实现(三)命令绑定
		MVVM模式解析和在WPF中的实现(三) 命令绑定 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在WPF中 ... 
- SQLServer执行命令出现“目录无效的提示”
		异常处理汇总-数据库系列 http://www.cnblogs.com/dunitian/p/4522990.html 一般都是清理垃圾清理过头了,把不该删的目录删了 网上说法: 问题描述: 1.s ... 
- SQLServer文件收缩-图形化+命令
		汇总篇:http://www.cnblogs.com/dunitian/p/4822808.html#tsql 收缩前 图形化演示: 不仅仅可以收缩日记文件,数据库文件也是可以收缩的,只不过日记收缩比 ... 
- 让 windows 下的命令行程序 cmd.exe 用起来更顺手
		在 Windows 下使用 Larave 框架做开发,从 Composer 到 artisan 总是避免不了和 cmd.exe 打交道,系统默认的命令行界面却是不怎么好看,且每行显示的字符数是做了限制 ... 
- [版本控制之道] Git 常用的命令总结(欢迎收藏备用)
		坚持每天学习,坚持每天复习,技术永远学不完,自己永远要前进 总结日常开发生产中常用的Git版本控制命令 ------------------------------main-------------- ... 
- git 命令
		切换仓库地址: git remote set-url origin xxx.git切换分支:git checkout name撤销修改:git checkout -- file删除文件:git rm ... 
- svn 常用命令总结
		svn 命令篇 svn pget svn:ignore // 查看忽略项 svn commit -m "提交说明" // 提交修改 svn up(update) // 获取最新版本 ... 
随机推荐
- JAVA常用集合
			List: ArrayList: 基于动态数组的有序集合.优点:可以根据索引index下标访问List中的元素,访问速度快:缺点是访问和修改中间位置的元素时慢(数组尾部插入元素以外). LinkedL ... 
- BFS总结
			能够用 BFS 解决的问题,一定不要用 DFS 去做! 因为用 Recursion 实现的 DFS 可能造成 StackOverflow! (NonRecursion 的 DFS 一来你不会写,二来面 ... 
- java模板设计模式
			1.概述 模板设计模式定义:定义一个操作中的算法骨架,将步骤延迟到子类中. 模板设计模式是一种行为设计模式,一般是准备一个抽象类,将部分逻辑以具体方法或者具体的构造函数实现,然后声明一些抽象方法,这样 ... 
- 解答VS2013编译报错不准确是什么原因
			1.当程序在错误时,VS2013编译报出的错误有时不会一起全部报出,而是按错误的英文首字母逐个报出的 2.如果报错的信息双击点过去查看时又发现无明显错误问题时,这个这个时候可以是VS编译的缓存问题,这 ... 
- 模板基础model
			一.Django-model基础 1.1ORM 映射关系: 表名<---------->类名 字段<---------->属性 表记录<---------->类实例 ... 
- opencv2.4.13+python2.7学习笔记--OpenCV中的图像处理--图像轮廓特征和几何矩
			阅读对象:对概率论中的期望有一点了解. 1.图像几何矩 1.1简述 图像的几何矩包括空间矩.中心矩和中心归一化矩.几何矩具有平移.旋转和尺度不变性,一般是用来做大粒度的区分,用来过滤显然不相关的图像. ... 
- 《vue.js快跑》总结:为什么选择VUE
			2019-3-31 为什么选择Vue 有这个一个需求,我们需要根据后端数据接口请求返回的数组在页面中按列表展示? 传统上我们使用jQuery的Ajax发送http请求,获取数据.判断列表数据是否存在, ... 
- expdp错误案例
			转自:https://www.cnblogs.com/kerrycode/p/3960328.html Oracle数据泵(Data Dump)使用过程当中经常会遇到一些奇奇怪怪的错误案例,下面总结一 ... 
- Shell输入和输出功能-3
- sflow介绍与安装过程
			介绍: sFlow技术是一种以设备端口为基本单元的数据流随机采样的流量监控技术,不仅可以提供完整的第二层到第四层甚至全网范围内的实时流量信息,而且可以适应超大网络流量(如大于10Gbit/s)环境下的 ... 
