第十五章 ECMAScript6新增的常用语法

2024-01-10 02:12

本文主要是介绍第十五章 ECMAScript6新增的常用语法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、声明关键字
  • 二、箭头函数
  • 三、解构赋值
  • 四、展开运算符
  • 五、对字符的补充
  • 六、Symbol
  • 七、对象的简写语法
  • 八、Set和Map
  • 九、for-of

一、声明关键字

  1. ES6新增的声明关键字:
    • letconst:声明变量
    • class:声明类
    • importexport:模块化开发
  2. letconst的特点
    1. 不存在提升
    2. 不允许重复声明
    3. 全局不会绑定到window
    4. 块级作用域
    5. 暂时性死区
    6. const声明的变量不允许修改地址
  3. 使用规范:const -> let -> var

二、箭头函数

  1. 箭头函数的特点等同于无名函数
    1. 赋值式创建函数的值
    2. 作为参数,回调函数
    3. 作为返回值,闭包函数
    4. 作为事件处理函数,不推荐
    5. 作为匿名函数的函数体使用
  2. 语法:
    • 完整语法:()=>{}
    • 极简语法:=>
      • 当有且只有一个参数时,可以省略小括号
      • 当有且直接返回了数据时,可以省略花括号和return,花括号和return必须同时省略
  3. 特点:
    1. 可读性差
    2. 语法极简
    3. 没有自身的this,自动使用外层this
    4. 不能被new执行

三、解构赋值

  1. 解开结构赋值,一般用于处理对象或数组
  2. 对象的解构
    • 规则:按照键和值的关系,一一对应,进行解构
    • 不存在的键,为undefined
    • 可以在声明变量时直接使用=号设置默认值
      • let {name,age=18,sex} = obj;
  3. 数组的解构
    • 规则:按照索引从左向右,一一对应,进行解构
    • 不存在的索引,为undefined
    • 可以在声明变量时直接使用=号设置默认值
      • let [q, w, e=0] = arr
  4. 字符的解构
    • 字符是一种类数组的结构,等同于数组的结构规则
      • let [a, s, d] = str;

四、展开运算符

  1. 一般用于快速展开复杂的数据,获取其内部的值
  2. 语法:...要展开的数据
  3. 展开对象:只能在能接收键值对的位置展开对象
    • 花括号内
const obj1 = {name:"Admin"};
// 花括号内
const obj2 = {...obj1};
  1. 展开数组:只能在能接收多个数据的位置展开数组
const arr = [3, 4, 5];
// 中括号内
const arr2 = [...arr];
// 参数
const max = Math.max(...arr);
// 伪数组转真数组
const arr3 = [...aLi];

五、对字符的补充

  1. 字符串模板:```
    • 支持反引号内回车换行
    • 反引号内的变量使用${}进行标记
const msg = "小王";
const str = `今天${msg}真好`;
const str2 = `${msg}今
天
送
我
一
件
礼
物`;
  1. 方法
    • str.repeat()
    • str.startsWith()
    • str.endsWith()
    • str.includes()
    • str.codePointAt()
    • String.fromCodePoint()

六、Symbol

  1. 类似于字符,基本数据类型,任何两个Symbol都不相等,用于表示标记值或状态
  2. 用于消除使用字符或数值或布尔等常规数据作为状态时的隐患
  3. 语法:const s = Symbol()

七、对象的简写语法

let name = "张三";
// 当对象的键和存储了值的变量名重名时,可以简写成一个单词
const obj = {name
}
console.log(obj);	// {name:"张三"}const obj = {// 方法可以省略冒号和functionshow(){console.log(this)}
}
obj.show(); // { show:f }

八、Set和Map

  1. 数据的打包形式
    • 数组对象:有序的可重复的值集合
    • 对象:无序的无重复的键值对集合
    • Set对象:无序的无重复的值集合
    • Map对象::无序的无重复的值值对集合
  2. Set:
    • 创建:const s = new Set()
    • 属性:s.size
    • 方法:
      • 添加数据:s.add( val )
      • 删除数据:s.delete( val )
      • 查询是否存在数据:s.has( val )
      • 清空数据:s.clear()
      • 获取所有键名:s.keys()
      • 获取所有值:s.values()
      • 获取所有键值:s.entries()
      • 遍历所有数据:s.forEach( callback )
  3. Map:
    • 创建:const m = new Map()
    • 属性:m.size
    • 方法:
      • 添加数据:m.set( key, val )
      • 查询数据:m.get( key )
      • 删除数据:m.delete( key )
      • 查询是否存在数据:m.has( key )
      • 清空数据:m.clear()
      • 获取所有键名:m.keys()
      • 获取所有值:m.values()
      • 获取所有键值:m.entries()
      • 遍历所有数据:m.forEach( callback )

九、for-of

  1. ES6新增的遍历语句:主要用于遍历set和map
  2. for-of遍历的是值
    • 能否遍历数组
    • 能否遍历对象
    • 能否遍历字符
  3. for-in遍历的是键
    • 能否遍历set
    • 能否遍历map
  • for-of 可以遍历:Set 和 Map 结构、数组、某些类似数组的对象(比如arguments对象、DOM NodeList 对象),以及字符串。

这篇关于第十五章 ECMAScript6新增的常用语法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/589215

相关文章

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Java常用注解扩展对比举例详解

《Java常用注解扩展对比举例详解》:本文主要介绍Java常用注解扩展对比的相关资料,提供了丰富的代码示例,并总结了最佳实践建议,帮助开发者更好地理解和应用这些注解,需要的朋友可以参考下... 目录一、@Controller 与 @RestController 对比二、使用 @Data 与 不使用 @Dat

Mysql中深分页的五种常用方法整理

《Mysql中深分页的五种常用方法整理》在数据量非常大的情况下,深分页查询则变得很常见,这篇文章为大家整理了5个常用的方法,文中的示例代码讲解详细,大家可以根据自己的需求进行选择... 目录方案一:延迟关联 (Deferred Join)方案二:有序唯一键分页 (Cursor-based Paginatio

Python实现常用文本内容提取

《Python实现常用文本内容提取》在日常工作和学习中,我们经常需要从PDF、Word文档中提取文本,本文将介绍如何使用Python编写一个文本内容提取工具,有需要的小伙伴可以参考下... 目录一、引言二、文本内容提取的原理三、文本内容提取的设计四、文本内容提取的实现五、完整代码示例一、引言在日常工作和学

Redis中的常用的五种数据类型详解

《Redis中的常用的五种数据类型详解》:本文主要介绍Redis中的常用的五种数据类型详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Redis常用的五种数据类型一、字符串(String)简介常用命令应用场景二、哈希(Hash)简介常用命令应用场景三、列表(L