ES6学习笔记:块级作用域
作用域分类
- 全局作用域
- 局部作用域
块级作用域
全局作用域示例
var i=2;
for (var i = 0; i < 10; i++) {
}
console.log(i);//10
- 这里就出现了意料之外的结果,此种原因是变量提升造成过的
局部作用域示例
!(function () {
console.log(b);//undefined
var b = 2;
})()
!(function () {
var b;
console.log(b);//undefined
b=2;
})()
这里就抛出来了一个问题,什么是变量提升?
JavaScript 中,变量可以在使用后声明,也就是变量可以先使用再声明。
ES6中引入了块级作用域的概念
//块级作用域使用方式
{
//...code
}
注意:使用 var 声明变量不受块级作用域限制,依旧会造成的变量提升,因此
引入了两个新的变量
- let
- const
使用示例
- 示例1
if(true){
var a=10;
}
console.log(a);//10
- 示例2
if(true){
let a=10;
}
console.log(a);//error: a is not defined
- 示例3
{
let a=2;
}
{
let a=3;
console.log(a);//3
}
- 示例4
{
const a=2;
console.log(a);//2
a = 3;//error:"a" is read-only
}
- 示例5
{
const obj={
name:'小明',
age:18
}
console.log(obj);//{name:"小明",age:18}
obj.name="小红";
console.log(obj);//{name:"小红",age:18}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。