ES6基础

栏目: JavaScript · 发布时间: 5年前

内容简介:首先看看ES5中得变量声明方式以上代码等同于再来看看

一、块级作用域

1. var

首先看看ES5中得变量声明方式

if (true) {
    var a = 2
}
console.log(a) // 2

以上代码等同于

var a
if (true) {
    a = 2
}
console.log(a)

以上可知 :

  1. 在块内部定义变量 变量提升,到函数最顶部
  2. 通过var声明的变量,无论在何处声明,均为 全局作用域

2.let 和 const

再来看看 ES6 中的 letconst

let

if (true) {
    let b = 2
}
console.log(b) // b is not defined

此时在{} 外部访问b 将会报错,因为 let 的作用域仅为 { } 的内部,及 块级作用域

const

if (true) {
    const c = 2
}
console.log(c) // c is not defined

const的作用域与let作用域相同:只在声明所在的块级作用域内有效

让我们看看const 更多的特性:

const 表示常量:

const d = 2
d = 3 // Assignment to constant variable.

此时,当 d 为 基本数据类型 的时候,改变其值,将会报错!!!

但是它的常量仅仅表示的是地址常量 对象的成员可以改变值

看看下面的例子:

const people = {name: '张三', age: 23}
people.age = 25
console.log(people) // {name: "张三", age: 25}

看看此时 people 已经被改变了

why?

对象是复杂的数据类型 它的地址保存在 栈里面, 值保存在堆里面

cosnt仅仅是保证这个地址不改变,至于地址对应的数据,是可以进行改变的

基本类型值在内存中占据固定大小的空间 因此被保存在栈内存中。比如 const a = 1 ; 这时候其直接保存在栈里面

结合网上的内容,个人理解而得 欢迎指正


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Google将带来什么?

Google将带来什么?

杰夫·贾维斯 / 陈庆新、赵艳峰、胡延平 / 中华工商联合出版社 / 2009-8 / 39.00元

《Google将带来什么?》是一本大胆探索、至关重要的书籍,追寻当今世界最紧迫问题的答案:Google将带来什么?在兼具预言、宣言、思想探险和生存手册性质的这样一《Google将带来什么?》里,互联网监督和博客先锋杰夫·贾维斯对Google这个历史上发展速度最快的公司进行了逆向工程研究,发现了40种直截了当、清晰易懂的管理与生存原则。与此同时,他还向我们阐明了互联网一代的新世界观:尽管它具有挑战性......一起来看看 《Google将带来什么?》 这本书的介绍吧!

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具