当前位置: 首页 > news >正文

Ecmascript(ES)标准

Ecmascript(ES)标准

ECMAScript(通常简称为 ES)是一种标准化的脚本语言,由 Ecma International 通过 ECMA-262 标准定义。ECMAScript 是 JavaScript 的规范版本,几乎所有的现代浏览器和许多服务器端环境(如 Node.js)都支持 ECMAScript。

ECMAScript 的历史

  1. ES1 (1997):首个版本,奠定了 JavaScript 的基础。
  2. ES2 (1998):对 ES1 的小修正。
  3. ES3 (1999):增加了正则表达式、错误处理等特性。
  4. ES4 (未发布):计划引入许多新特性,但由于过于激进,最终没有发布。
  5. ES5 (2009):增加了严格模式、JSON 支持、数组和对象的新方法等。
  6. ES6 / ES2015 (2015):引入了许多重要特性,如模块、类、箭头函数、解构赋值、模板字符串等。
  7. ES2016 (2016):增加了 Array.prototype.includes 和指数运算符 **
  8. ES2017 (2017):增加了异步函数、共享内存和原子操作等。
  9. ES2018 (2018):增加了异步迭代、正则表达式改进、REST 参数和展开运算符等。
  10. ES2019 (2019):增加了 flatflatMap 方法、Object.fromEntries、可选的 catch 绑定等。
  11. ES2020 (2020):增加了 BigIntPromise.allSettled、空值合并运算符 ?? 等。
  12. ES2021 (2021):增加了逻辑赋值运算符、String.prototype.replaceAll 等。
  13. ES2022 (2022):增加了类的私有属性、顶级 await、错误原因等。
  14. ES2023 (2023):增加了 Array.findLastArray.findLastIndexIntl.NumberFormat 的新选项等。

主要特性

1. 基础类型和结构
  • 原始类型
    • Number:表示数值,包括整数和浮点数。
    • String:表示文本。
    • Boolean:表示真(true)或假(false)。
    • Null:表示空值。
    • Undefined:表示未定义的值。
    • Symbol:表示唯一标识符,常用于对象属性键。
    • BigInt:表示任意大小的整数。
    复合类型
    • Object:用于存储键值对。
    • Array:用于存储有序的数据集合。
    • Function:用于定义可执行的代码块。
2. 函数
  • 箭头函数

    箭头函数提供了一种更简洁的函数定义方式,并且在函数体内使用 this 时不会绑定新的 this 值。

    const add = (a, b) => a + b;
    console.log(add(1, 2)); // 输出 3
    
    默认参数

    允许在函数定义时为参数指定默认值。

    function greet(name = 'Guest') {console.log(`Hello, ${name}!`);
    }
    greet(); // 输出 Hello, Guest!
    greet('Alice'); // 输出 Hello, Alice!
    
    剩余参数

    允许将不定数量的参数收集到一个数组中。

    function sum(...args) {return args.reduce((a, b) => a + b, 0);
    }
    console.log(sum(1, 2, 3, 4)); // 输出 10
    
3. 对象
  • 解构赋值

    可以从对象或数组中提取数据并赋值给变量。

    const person = { name: 'Alice', age: 30 };
    const { name, age } = person;
    console.log(name); // 输出 Alice
    console.log(age); // 输出 30const [a, b, c] = [1, 2, 3];
    console.log(a, b, c); // 输出 1 2 3
    
    扩展运算符

    可以用来合并对象或数组。

    const obj1 = { a: 1, b: 2 };
    const obj2 = { ...obj1, c: 3 };
    console.log(obj2); // 输出 { a: 1, b: 2, c: 3 }const arr1 = [1, 2];
    const arr2 = [...arr1, 3, 4];
    console.log(arr2); // 输出 [1, 2, 3, 4]
    
4. 类
  • 类定义

    类是面向对象编程的重要组成部分,用于定义对象的结构和行为。

    class Person {constructor(name) {this.name = name;}greet() {console.log(`Hello, my name is ${this.name}.`);}
    }const alice = new Person('Alice');
    alice.greet(); // 输出 Hello, my name is Alice.
    
    静态方法

    静态方法属于类本身,而不是类的实例。

    class MathUtils {static add(a, b) {return a + b;}
    }console.log(MathUtils.add(1, 2)); // 输出 3
    
    私有属性和方法

    私有属性和方法只能在类的内部访问。

    class Counter {#count = 0;increment() {this.#count++;}getCount() {return this.#count;}
    }const counter = new Counter();
    counter.increment();
    console.log(counter.getCount()); // 输出 1
    
5. 模块
  • 导入导出

    模块化开发有助于组织和管理代码。

    // math.js
    export function add(a, b) {return a + b;
    }export function subtract(a, b) {return a - b;
    }// main.js
    import { add, subtract } from './math.js';console.log(add(1, 2)); // 输出 3
    console.log(subtract(5, 3)); // 输出 2
    
6. 异步编程
  • Promise

    Promise 是处理异步操作的一种方式,可以更好地管理回调地狱。

    const fetchData = url => {return new Promise((resolve, reject) => {setTimeout(() => {resolve({ data: 'Fetched data' });}, 1000);});
    };fetchData('https://example.com').then(data => console.log(data)).catch(error => console.error(error));
    
    async/await

    async/await 是基于 Promise 的语法糖,使异步代码看起来更像同步代码。

    const fetchData = async url => {try {const response = await fetch(url);const data = await response.json();return data;} catch (error) {console.error(error);}
    };fetchData('https://example.com').then(data => console.log(data)).catch(error => console.error(error));
    
7. 其他特性
  • 模板字符串

    模板字符串允许在字符串中嵌入表达式。

    const name = 'Alice';
    const message = `Hello, ${name}!`;
    console.log(message); // 输出 Hello, Alice!
    
    迭代器和生成器

    迭代器和生成器提供了处理数据流的新方式。

    function* generateSequence() {yield 1;yield 2;yield 3;
    }const generator = generateSequence();
    console.log(generator.next().value); // 输出 1
    console.log(generator.next().value); // 输出 2
    console.log(generator.next().value); // 输出 3
    
    代理和反射

    代理和反射提供了拦截和控制对象操作的能力。

    const handler = {get(target, prop) {return target[prop];},set(target, prop, value) {target[prop] = value;}
    };const target = { a: 1 };
    const proxy = new Proxy(target, handler);console.log(proxy.a); // 输出 1
    proxy.a = 2;
    console.log(proxy.a); // 输出 2
    

资源和工具

  • 官方规范:https://tc39.es/ecma262/
  • Babel:将新版本的 JavaScript 转换为向后兼容的代码,以便在旧环境中运行。
  • MDN Web 文档:https://developer.mozilla.org/en-US/docs/Web/JavaScript
  • ECMAScript 提案:https://github.com/tc39/proposals

希望这些详细的解释能帮助您更好地理解和使用 ECMAScript。

相关文章:

Ecmascript(ES)标准

Ecmascript(ES)标准 ECMAScript(通常简称为 ES)是一种标准化的脚本语言,由 Ecma International 通过 ECMA-262 标准定义。ECMAScript 是 JavaScript 的规范版本,几乎所有的现代浏览器和许多服务器端环境&a…...

易泊车牌识别相机:4S 店的智能之选

在当今数字化时代,科技的进步不断为各个行业带来更高效、便捷的解决方案。对于 4S 店来说,易泊车牌识别相机的出现,无疑为其运营管理带来了全新的变革。 一、易泊车牌识别相机的强大功能 易泊车牌识别相机以其卓越的性能和精准的识别能力&…...

Webpack 深度解析与实战指南

文章目录 前言一、安装于基本配置安装Webpack 和 Webpack CLI创建基本配置文件 二、加载器常见的加载器配置加载器 三、插件(Plugins)常用的插件配置插件 四、性能优化缓存代码分割Tree Shaking压缩 五、开发服务器安装服务器配置服务器启动服务器生产环…...

【RabbitMQ】06-消费者的可靠性

1. 消费者确认机制 没有ack,mq就会一直保留消息。 spring:rabbitmq:listener:simple:acknowledge-mode: auto # 自动ack2. 失败重试机制 当消费者出现异常后,消息会不断requeue(重入队)到队列,再重新发送给消费者。…...

【K8S系列】如何监控集群CPU使用率并设置告警的分析与详细解决方案

监控 Kubernetes 集群的 CPU 使用率并设置告警是确保集群健康和性能的关键。以下是几种常见的方案,每种方案的具体步骤都进行了详细说明。 方案 1: 使用 Prometheus 和 Grafana 1. 安装 Prometheus 和 Grafana 1.1 使用 Helm 安装 Prometheus 添加 Helm 仓库: hel…...

解线性方程组(二)

实验类型:●验证性实验 ○综合性实验 ○设计性实验 实验目的:进一步熟练掌握用Jacobi迭代法和Gauss-Seidel法解线性方程组的算法,提高编程能力和解算线性方程组问题的实践技能。 实验内容: 1)取初值性x(0)(0,0,0,0)T, 精度要求ε…...

HarmonyOS Next 实战卡片开发 02

HarmonyOS Next 实战卡片开发 02 卡片开发中,还有一个难点是显示图片。其中分为显示本地图片和显示网络图片 显示本地图片 卡片可以显示本地图片,如存放在应用临时目录下的图片。路径比如 /data/app/el2/100/base/你的项目boundleName/temp/123.png 以…...

FastDDS服务发现之PDP的收发

目录 PDP发送PDP接收EDP更新 EntityID 通过FastDDS服务发现之PDP和EDP的创建这一节内容,可以了解服务发现的概念,机制和PDP/EDP中各类对象的创建,本文详细介绍Simple PDP发送数据,接收数据和处理报文的流程。 PDP发送 通过在RTP…...

【计网不挂科】计算机网络期末考试——【选择题&填空题&判断题&简述题】试卷(2)

前言 大家好吖,欢迎来到 YY 滴计算机网络 系列 ,热烈欢迎! 本章主要内容面向接触过C的老铁 本博客主要内容,收纳了一部门基本的计算机网络题目,供yy应对期中考试复习。大家可以参考 本章是去答案版本。带答案的版本在下…...

关于有机聚合物铝电容的使用(2)

在使用时需要特别注意的几个应用场景: 在有较长供电电缆或PCB电源布线较长的场合。 这个场景应当仍与有机聚合物铝电容的耐压有关。 假设在相同的冲击电流下,较长的供电电缆和PCB布线,那么电缆和PCB布线上产生的冲击电压就会越高。故而&…...

Linux -- 进程初印象

目录 预备知识 切入点 PCB 看见进程 pid getpid 函数 预备知识 Linux -- 冯诺依曼体系结构(硬件)-CSDN博客https://blog.csdn.net/2301_76973016/article/details/143598784?spm1001.2014.3001.5501 Linux -- 操作系统(软件&#xf…...

【超级简单】Facebook脸书视频下载一键保存手机

Facebook作为目前服务全球30亿用户,尤其是出海和跨境用户没有办法忽视的平台,提供了一个在线平台,使用户分享照片、视频、状态更新和链接等内容,然而,令人遗憾的是,用户没有办法直接将照片和视频保存到本地…...

昇思大模型平台打卡体验活动:项目2基于MindSpore通过GPT实现情感分类

昇思大模型平台打卡体验活动:项目2基于MindSpore通过GPT实现情感分类 1. 载入与处理数据集 在情感分类任务中,我们使用了IMDB数据集,首先需要对数据进行加载和处理。由于原数据集没有验证集,我们将训练集重新划分为训练集和验证…...

【JAVA】会员等级互通匹配数据库表设计

1、使用数据库:mysql数据库 设计四张表: 会员互通合作商配置表 会员互通合作商会员等级配置表 会员互通合作日志表 会员互通合作等级映射表 CREATE TABLE user_level_partner ( id bigint NOT NULL AUTO_INCREMENT, partner_novarchar(100) DE…...

论文阅读:基于语义分割的非结构化田间道路场景识别

论文地址:DOI: 10.11975/j.issn.1002-6819.2021.22.017 概要 环境信息感知是智能农业装备系统自主导航作业的关键技术之一。农业田间道路复杂多变,快速准确地识别可通行区域,辨析障碍物类别,可为农业装备系统高效安全地进行路径规…...

linux部分问题以及解决方式

目录 1.ubuntu桌面不显示了,只有命令行1.1启动gdm3服务1.2安装lightdm桌面管理包 1.ubuntu桌面不显示了,只有命令行 有如下两种解决方式。 1.1启动gdm3服务 这种方法只能临时生效,每次重启都要手动启动 sudo service gdm3 restart 1.2安装…...

qt QTreeWidget详解

1、概述 QTreeWidget 是 Qt 框架中的一个类,用于以树形结构展示数据。它基于 QTreeView 并提供了更高级别的接口,使得添加、删除和管理树形结构中的项变得更加简单。QTreeWidget 支持多级嵌套,每个项(QTreeWidgetItem&#xff09…...

注意力机制的目的:理解语义;编码器嵌入高纬空间计算;注意力得分“得到S*V”;解码器掩码和交叉注意力层用于训练;最终的编码器和输出实现大模型

目录 注意力机制的目的:理解语义中的它是小白兔 词编码器嵌入高纬空间 计算注意力得分“得到S*V” 权重QKV:连接权重 训练阶段使用解码器:翻译后的语句 解码器掩码和交叉注意力层用于训练 最终的编码器和输出实现大模型 Transformer模型中,QKV QKV的作用 举例说明…...

[java][jdk]JDK各个版本的核心特性

JDK 8至JDK 21的主要新特性概览: JDK 8 Lambda表达式:引入了函数式编程的特性,使得代码更加简洁和灵活。Stream API:提供了一种新的抽象,可以让你以声明性方式处理集合数据。新的日期和时间API:引入了jav…...

双十一”买买买!法官告诉你注意这些法律问题

“双十一”等购物节来临之际,某些电商平台为了吸引消费者提前下单预订商品,通过大力宣传付定金可享受更多优惠等方式开启预售模式。那么,如果消费者在支付定金后,因各种原因最终没有支付尾款,能否要求商家退还定金&…...

PyQt5

基于PyQt5的重绘机制实现加载页面 效果预览代码说明控件初始化超时回调重绘事件缩放事件 代码获取 效果预览 直接看图,效果展现为跟随黑点顺时针转动,且有明暗变化 代码说明 控件初始化 initUI主要用于初始化用户界面(UI)。它创建了一个具有特定样式…...

【Linux】常用命令(2.6万字汇总)

文章目录 Linux常用命令汇总1. 基础知识1.1. Linux系统命令行的含义1.2. 命令的组成 2. 基础知识2.1. 关闭系统2.2. 关闭重启2.3. 帮助命令(help)2.4. 命令说明书(man)2.5. 切换用户(su)2.6.历史指令 3.目录…...

Vue3-06_路由

路由 后台路由是根据请求url,匹配请求处理的后台模块(路径) 前台根据访问路径,决定显示的内容。 路由就是: 访问hash 与内容的对应关系 路由的工作方式 用户点击页面的路由链接导致url地址栏中的Hash值发生了变化前…...

物理验证Calibre LVS | SMIC Process过LVS时VNW和VPW要如何做处理?

SMIC家工艺的数字后端实现PR chipfinish写出来的带PG netlist如下图所示。我们可以看到标准单元没有VNW和VPW pin的逻辑连接关系。 前几天小编在社区星球上分享了T12nm ananke_core CPU低功耗设计项目的Calibre LVS案例,就是关于标准单元VPP和VBB的连接问题。 目前…...

量化分析工具日常操作日记-5-通合科技

使用量化分析微信小程序工具“梦想兔企业智能风险分析助手”日常操作日记-5-军工-通合科技(300491)。 周末国家新政策,要大力支持军工行业,我用工具挖掘了两个低位股,供大家参考。通合科技(300491&#xff…...

windows和linux验证MD5码方式

一、linux linux自带MD5码验证: $ md5sum target_file.txt 二、windows windows自带的MD5码验证: $ certutil -hashfile target_file.txt MD5...

构造函数原型对象语法、原型链、原型对象

目录 一、前言 二、编程思想 面向过程 面向对象 三、构造函数 四、原型对象 constructor 属性 对象原型 原型继承 原型链 一、前言 通过本篇博客,我们将了解面向对象编程的一般特征,掌握基于构造函数原型对象的逻辑封装,掌握基于原…...

鸿蒙UI开发——自定义UI绘制帧率

1、概 述 随着设备屏幕的不断演进,当前主流设备采用LTPO屏幕(可变刷新率屏幕),此类屏幕支持在多个档位之间切换屏幕帧率。 对于快速变化的内容,如射击游戏,交互动画等,显示帧率越高&#xff0…...

鸿蒙基本组件结构

组件结构 1. 认识基本的组件结构 ArkTS通过装饰器Component 和Entry 装饰 struct 关键字声明的数据结构,构成一个自定义组件 自定义组件中提供了一个build函数,开发者需要在函数内以链式调用的方式进行基本的UI描述,UI描述的方法请参考UI描述…...

柔性鞋材振动刀智能视觉裁切机市场报告:未来几年年复合增长率CAGR为5.4%

震动刀切割设备是一种利用振动刀片在各种非金属材料表面上切割的设备,振动刀切割机利用刀片高频振动和360度旋转,能保证每分钟上万次的振动频率,可在平面进行垂直切割,锋利裁剪。震动刀切割设备切割速度快,可以单层切割…...

博物馆建设网站/国家培训网官网

场景:用户表、项目表、用户和项目中间表 多对多表的实体创建,记得在配置文件中加: spring.jpa.database-platformorg.hibernate.dialect.MySQL5InnoDBDialect MyISAM和InnoDB详解:https://blog.csdn.net/shuaijunlan/article/de…...

黑客软件资源网站/seo排名点击器原理

最近收到不少粉丝的来信,称自己找工作找到崩溃,原因各种各样:大学生:毕业后想进一线大厂,不知道怎么准备面试;待业青年:想从事互联网高薪岗位,却因没有技术基础一直犹豫纠结&#xf…...

eclipce做网站/百度官方官网

1.百度地图开放平台申请百度地图KEY 2. 运行 npm install vue-baidu-map –save3.在index.html中导入 <script type="text/javascript" src="http://api.map.baidu.com/getscript? v=2.0&ak=xxxxxxxxxx"></script>4.创建damo.vue <…...

平面设计师需要学历/seo服务是什么

2019独角兽企业重金招聘Python工程师标准>>> 环境准备&#xff1a;以下所有部署操作都在vm虚拟机环境下进行实现,如果转为生产环境只需配置对应ip地址即可,linux下基础配置请参考文摘CentOs6.5基本环境配置&#xff08;一&#xff09;&#xff1a;基本环境配置 http…...

论文 网站建设/网站平台做推广

RoboWare Studio是一个ROS集成开发环境。它使 ROS开发更加直观、简单、并且易于操作。可进行ROS工作区及包的管理、代码编辑、构建及调试。 RoboWare官网&#xff1a;http://cn.roboware.me/#/home 因为官网的教程打不开&#xff0c;自己折腾了好久&#xff0c;写点东西记录一…...

单仁资讯做网站怎样/竞价排名深度解析

Ir(II)配合物金属-配体电荷转移(3MLCT)激发态&#xff09; 在常见的几种重金属配合物中&#xff0c;Ir(II)配合物由于磷光寿命相对较短和发光量子效率高&#xff0c;而成为电致发光领域研究的热点.另外其发射波长受配体结构影响,改变配体结构可以使配合物的发光颜色在整个可见…...