ES6 学习(一)-- 基础知识

文章目录

  • [1. 初识 ES6](#1. 初识 ES6)
  • [2. let 声明变量](#2. let 声明变量)
  • [3. const 声明常量](#3. const 声明常量)
  • [4. 解构赋值](#4. 解构赋值)

1. 初识 ES6

ECMAScript6.0(以下简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了。它的目标,是使得」JavaScript语言可以用来编写复杂的大型应用程序,成为企业级开发语言。

2. let 声明变量

  1. let 声明变量是局部变量
    var 声明变量会变成全局变量;
javascript 复制代码
{
            var i = 0;
        }
        console.log(i); // 0 

而let 声明变量则是局部变量;

javascript 复制代码
{
            let i = 0;
        }
        console.log(i); // 报错
  1. 不允许重复声明

使用var 重复声明变量: 覆盖之前的值

使用let 重复声明变量:报错!

  1. 变量提升没有了

暂存/时性死区:

在代码块中使用let 变量定义之前变量是不可用的且该变量是存在的,此时我们把这块内容称作暂存/时性死区。

  1. 不与顶层对象挂钩

    // 100

// undefined

3. const 声明常量

  1. const 声明的是常量,需要在声明时就赋值,后期值不可以修改;

  2. 不能重复定义;

  3. 出现在块级定义域中为局部变量,外部不可访问;

  4. 声明不提升,会出现暂存性死区

  5. 不与顶层对象挂钩

    // undefined

const 声明常量一般是不可以被再次赋值的,但是如果const 定义的常量是一个对象(复杂数据类型),那么该变量只是存储了一个地址信息,通过obj.xxx 还是可以进行修改的。

如果不想要该变量被修改就需要使用到freeze(),但是该函数只能冻住第一层属性,如果属性值是复杂数据类型,那么还是能够进行修改的。

4. 解构赋值

解构赋值,就是快速的从对象或者数组中取出成员的一个语法方式。

  1. 数组传参

    // a=1 b=2 c=3

两个变量交换值:

之前需要定义临时变量进行辅助,而现在

// a = 1

// a = 3

// b = 2

  1. 对象传参

    // kerwin 100

// 报错

因为code 变量定义了两次

这种情况我们采用以下写法

let {data, code:co} = res;

// 11111111 200 没有错误

此时code 中如果有err 变量,输出值就覆盖默认值 没有错误 。

  1. 使用函数对解构赋值进行传参
  2. 字符串解构

    // k e r
相关推荐
像我这样帅的人丶你还6 分钟前
使用 Next.js + Prisma + MySQL 开发全栈项目
前端
FPGA小迷弟6 分钟前
FPGA 时序约束基础:从时钟定义到输入输出延迟的完整设置
前端·学习·fpga开发·verilog·fpga
毛骗导演25 分钟前
@tencent-weixin/openclaw-weixin 插件深度解析(四):API 协议与数据流设计
前端·架构
毛骗导演28 分钟前
@tencent-weixin/openclaw-weixin 插件深度解析(二):消息处理系统架构
前端·架构
IT_陈寒1 小时前
深入理解JavaScript:核心原理与最佳实践
前端·人工智能·后端
MrGud1 小时前
Cesium中的坐标系及其转换
前端·cesium
小付学代码1 小时前
香港地图可编辑版
前端
兆子龙1 小时前
TypeScript高级类型编程:从入门到精通
前端·后端
SuperEugene1 小时前
Vue3 模板语法规范实战:v-if/v-for 不混用 + 表达式精简,避坑指南|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架
IT_陈寒1 小时前
Python开发者的效率革命:这5个技巧让你的代码提速50%!
前端·人工智能·后端