ES6 常用语法

目录

1. 声明变量: let 和 const(无变量提升,块级作用域,不可重复声明)

2. 箭头函数

3. 模板字符串`,${}

4. 解构赋值

5. 默认参数

6. 展开运算符

7. 类和继承

8. Promise 对象


1. 声明变量: let 和 const(无变量提升,块级作用域,不可重复声明)

let 声明的变量可以被修改;const 声明的变量是常量,不可被修改。

let x = 10;
const PI = 3.14;

2. 箭头函数

更简洁,绑定了词法作用域的 this 值。不会创建自己的 this,而是继承了上下文中的 this , this 始终指向定义时所在的作用域。

// 传统函数定义
function add(a, b) {return a + b;
}// 箭头函数定义
const add = (a, b) => a + b;// 词法作用域绑定
function Person() {this.age = 0;setInterval(() => {this.age++; // this 指向 Person 对象}, 1000);
}// 隐式返回,可省略 return 关键字
const add = (a, b) => a + b;// 适用于回调函数
const arr = [1, 2, 3];
const doubled = arr.map(num => num * 2);

3. 模板字符串`,${}

使用反引号 \` ${} 来插入变量或表达式,使字符串拼接更简洁。

const name = 'Alice';
console.log(`Hello, ${name}!`);

4. 解构赋值

允许按照一定模式从数组或对象中提取值,然后赋值给变量

const [x, y] = [1, 2];
const {name, age} = {name: 'Alice', age: 30};

5. 默认参数

函数参数可以指定默认值,当调用函数时没有传入对应参数时,使用默认值。

function greet(name = 'World') {console.log(`Hello, ${name}!`);
}

6. 展开运算符

展开运算符(`...`)可以将数组或对象展开为独立的元素,或者将多个参数合并为数组。

const arr1 = [1, 2, 3];
const arr2 = [...arr1, 4, 5];
const obj1 = {a: 1, b: 2};
const obj2 = {...obj1, c: 3};

7. 类和继承

ES6 引入了类(class)和继承的语法糖,更易于面向对象编程。

class Animal {constructor(name) {this.name = name;}speak() {console.log(`${this.name} makes a noise.`);}
}class Dog extends Animal {constructor(name) {super(name);}speak() {console.log(`${this.name} barks.`);}
}const dog = new Dog('Spot');
dog.speak(); // Spot barks.

8. Promise 对象

Promise 是一种用于异步编程的对象,用于表示一个异步操作的最终完成或失败及其结果值。

Promise 对象的特点:

  1. 状态pending(进行中)、fulfilled(已成功)和 rejected(已失败)。状态一旦改变,就不会再变,从 pending 到 fulfilled 或者从 pending 到 rejected。

  2. 状态转换只能由 pending 转换为 fulfilled 或者 rejected,并且一旦状态确定就不可再改变。

  3. 结果值:状态变为 fulfilled 时,会传递一个结果值;状态变为 rejected 时,会传递一个拒绝原因(错误信息)。

const promise = new Promise((resolve, reject) => {// 执行异步操作setTimeout(() => {// 异步操作成功,调用 resolve 并传递结果值resolve('Success!');// 异步操作失败,调用 reject 并传递拒绝原因// reject('Error!');}, 1000);
});promise.then(// 成功时执行的回调函数result => {console.log(result); // 'Success!'},// 失败时执行的回调函数error => {console.error(error); // 'Error!'}
);

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

nodejs工具脚本json转excel

json转excel 主要使用 sheetjs 库 vim convertJsonToExcel.js 封装转换方法 import fs from fs; import XLSX from xlsx;/*** 扁平化嵌套json对象* param {Object} jsonObj* param {String} prefix* returns*/ export function flattenKeys(jsonObj, prefix ) {const resul…

java-springmvc 01

MVC就是和Tomcat有关。 01.MVC启动的第一步,启动Tomcat 02.Tomcat会解析web-inf的web.xml文件

桐乡上元会计——管理会计在企业中的价值

1.管理会计处于企业价值管理的核心地位 从管理会计与财务会计的对比中不难看出,管理会计在企业中应占有非常重要的地位。管理会计是社会生产力进步、管理水平提高的结果,也是一门有助于提高经济效益的科学。在西方的企业中,会计机构隶属于支…

战姬物语部署

一.准备环境 #关闭seliunx和防火墙 setenforce 0 systemctl stop firewalld systemctl disable firewalld #配置源,并安装常用工 curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo curl -o /etc/yum.repos.d/epel.repo …

通达信-主力预警源码及使用方法(指标叠加使用)手机电脑均可

指标用法介绍 1.指标盘中预警适合盘中抓涨停和**适合超短和短线操作**。实盘预警有一定的概率抓到涨停个股,跟主力吃肉,不过也并非所有信号都能涨停,根据实盘跟踪观察来看,当天不涨停的个股大部分第二天第三天都能有比较安全的点位出局。也有比较多的信号,后续很多天的表…

Nginx出现403 Forbidden、404 Not Found错误的解决方案

一、Docker创建Nginx容器 Docker命令 docker run -d \--name nginx \-p 80:80 \-v /root/nginx/dist:/usr/share/nginx/html \-v /root/nginx/nginx.conf:/etc/nginx/nginx.conf \nginxnginx.conf worker_processes 1;events {worker_connections 1024; }http {include …

Spring Task 定时任务(含结合cron 表达式)

目录 一、Spring Task的介绍 二、使用方法 2.1 配置类启用定时任务支持: 2.2 同步定时任务 ​编辑2.3 fixedRate 可以看出不能满足我们的日常需求 那如何让其开启异步呢(开启多个线程工作) 三、Spring Task 结合cron表达式 3.1 corn 表…

【动态规划】dp 路径问题(不同路径、路径最小和、地下城游戏...)

文章目录 1. 前言 - 理解动态规划算法1.5 关于dp路径问题2. 例题2.1_不同路径Warning. 关于状态表示 3. 算法题3.1_不同路径II3.2_珠宝的最高价值3.3_下降路径最小和3.4_最小路径和3.5_地下城游戏关于状态表示的两种选法: 1. 前言 - 理解动态规划算法 关于 动态规划…

超越GPT-4V,苹果多模态大模型上新,神经形态计算加速MLLM(一)

4月8日,苹果发布了其最新的多模态大语言模型(MLLM )——Ferret-UI,能够更有效地理解和与屏幕信息进行交互,在所有基本UI任务上都超过了GPT-4V! 苹果开发的多模态模型Ferret-UI增强了对屏幕的理解和交互&am…

做生意能只用电子名片吗?

做生意,收到纸质名片是不可避免的,电子名片不可能完全能代替纸质名片,如果想方便管理纸质名片的话,将名片拍照转为Excel是一种不错的方案,它可以让我们方便地通过表格筛选或搜索需要的信息,极大地提高了信息…

cdh cm界面HDFS爆红:不良 : 该 DataNode 当前有 1 个卷故障。 临界阈值:任意。(Linux磁盘修复)

一、表现 1.cm界面 报错卷故障 检查该节点,发现存储大小和其他节点不一致,少了一块物理磁盘 2.查看该磁盘 目录无法访问 dmesg检查发现错误 dmesg | grep error二、解决办法 移除挂载 umount /data10 #可以移除挂载盘,或者移除挂载目…

【C语言】深入解析选择排序算法

一、算法原理二、算法性能分析三、C语言实现示例四、总结 一、算法原理 选择排序(Selection Sort)是一种简单直观的排序算法。它的工作原理是不断地选择剩余元素中的最小(或最大)元素,放到已排序的序列的末尾&#xff…

RCE漏洞及其绕过——[SWPUCTF 2021 新生赛]easyrce、caidao、babyrce

目录 什么是Shell 1、Shell简介 2、印刷约定 一、什么是RCE 漏洞产生条件: 漏洞检测: 1.远程命令执行 system()函数: passthru()函数: exec()函数: 无回显 shell_exec()函数: 2.远程代码执行 e…

【算法刷题day28】Leetcode:93.复原IP地址 78.子集 90.子集II

93.复原IP地址 文档链接:[代码随想录] 题目链接:93.复原IP地址 题目: 给定一个只包含数字的字符串,复原它并返回所有可能的 IP 地址格式。 有效的 IP 地址 正好由四个整数(每个整数位于 0 到 255 之间组成,…

【React】Ant Design自定义主题风格及主题切换

Ant Design 的自定义主题,对于刚入手的时候感觉真是一脸蒙圈,那今天给它梳理倒腾下; 1、自定义主题要点 整体样式变化,主要两个部分: 1.1、Design Token https://ant.design/docs/react/customize-theme-cn#theme 官…

2024信友队智灵班春季 Test1 总结

4月模考 死亡回放 模考时间线 1:30 比赛开始,读 T1 宇宙爆炸 的题1:50 自己手模了几组样例,得出了一个错误结论,打出了第一版错误代码,然后上交( Wrong Answer 20 \color{red}\text{Wrong\ Answer\ 20} Wrong Answer …

【Vue 异步更新和 $nextTick】

文章目录 异步更新机制$nextTick 方法 异步更新机制以及 $nextTick 方法都与 Vue 的响应式系统密切相关,对于开发高效、流畅的应用至关重要。 异步更新机制 Vue 的数据更新是异步执行的。修改 Vue 实例的数据时,Vue 并不会立即更新 DOM。它将数据变更放…

每日一题(PTAL2-008):最长对称子串--分类讨论+遍历

最长对称子串的长度有可能是奇数也有可能是偶数&#xff0c;因此在遍历时要同时考虑这两种情况。 #include<bits/stdc.h> using namespace std;int main() {string s;getline(cin,s);int n s.size();int res 0; // 初始化为0&#xff0c;因为空字符串也是对称的for (i…

VMware最新下载安装

1、打开浏览器 搜索VMware官网&#xff0c;点进去。如图&#xff1a; 这里有两种下载方法&#xff0c;便洁就是我这种&#xff0c;还有一种就是注册账号之后下载就完全没有必要了&#xff0c;而且基本注册不了&#xff0c;不太好注册。 2、选择"产品"第二个选项 …

Oracle数据库从入门到精通系列之二十:Linux上使用容器数据库(CDB)方式部署Oracle数据库19c详细步骤

@TOC 一、Oracle 数据库部署类型 Oracle数据库支持以下部署类型: 容器数据库(CDB) 可以包含多个可插入数据库 (PDB) 的数据库。数据库客户端连接到每个 PDB,就好像它是标准的非 CDB 数据库一样。非容器数据库(非CDB) 标准Oracle数据库,不支持创建可插拔数据库。二、安…