ES6之------------------let,const
来源:互联网 发布:电力猫网络dns不正常 编辑:程序博客网 时间:2024/05/16 07:08
最近不是太忙,准备仔细研究下Es6;持续更新中;
let,const
let不像var那样会发生“变量提升”现象。所以,变量一定要在声明后使用,否则报错。
{
let a = 10;
var b = 1;
}
a //
b //
var a = [];for (let i = 0; i <10; i++) {
a[i] =function (){
console.log(i);
};
}
a[6]();//
死区:ES6明确规定,如果区块中存在let和const命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。
var tmp =123;
if (true) {
tmp = 'abc';//
let tmp;
}
function bar(x = y, y = 2) {
return [x, y];
}
bar(); //
不允许重复声明
function () {
let a = 10;
var a = 1;
}
块级作用域之中,函数声明语句的行为类似于let,块级作用域之外不可引用。
function f() { console.log('I am outside!'); }
(function () {
if (false) {
// 重复声明一次函数f
function f() { console.log('I am inside!'); }
}
f();
}());
考虑到环境导致的行为差异太大,应该避免在块级作用域内声明函数。如果确实需要,也应该写成函数表达式,而不是函数声明语句。
function f() {}
let f = function () {}
do 表达式-----------(目前只提案,还不支持)
let x = do {
let t = f();
t * t + 1; return t;
};
Const声明一个只读的常量 ;必须立即初始化
const命令只是保证变量名指向的地址不变,并不保证该地址的数据不变,所以将一个对象声明为常量必须非常小心。---------针对复合类型变量
Object.freeze-------可以将对象冻结
let命令、const命令、class命令声明的全局变量,不属于顶层对象的属性。也就是说,从ES6开始,全局变量将逐步与顶层对象的属性脱钩;
ES5的顶层对象,本身也是一个问题,因为它在各种实现里面是不统一的。
· 浏览器里面,顶层对象是window,但 Node 和 Web Worker 没有window。
· 浏览器和 Web Worker 里面,self也指向顶层对象,但是Node没有self。
· Node 里面,顶层对象是global,但其他环境都不支持。
引入global作为顶层对象,所有环境下,都可以从它拿到顶层对象---(提案)
- ES6之let,const
- ES6之------------------let,const
- ES6之let,const
- ES6之 let与const
- ES6学习之——let、const
- ES6学习笔记之《let 和 const》
- ES6 之 let 和 const 命令
- ES6之let和const命令
- 学习笔记:ES6之let和const
- 【ES6】let和const
- es6 箭頭函數 let, const
- es6---(let const)
- es6 let和const
- ES6---let与const
- ES6-let,const
- [es6] let & const
- 【es6】 let & const
- ES6-let和const
- 逆向实战之入门去除某果TV广告
- 蓝牙BlueTooth
- Maven install报MojoExecutionException
- linux安装bcompare
- 关于调用listFile()在遍历含有乱码文件时出现input is not valid Modified UTF-8错误的解决方法
- ES6之------------------let,const
- z-index的用法,不生效问题
- VC char和TCHAR之间转换
- Java并发编程:volatile关键字解析
- 2048
- clear清除
- ARM Linux 3.x的设备树(Device Tree)
- [k8s]k8s架构图解
- webview加载富文本混淆后出错