快速掌握ES6
什么是ES6
ES6(ECMAScript 6),也被称为ES2015,是JavaScript的第六个版本,于2015年发布。ES6引入了许多新的语法和功能,旨在提高JavaScript的开发效率和代码质量。
ES6的一些主要特性和改进包括:
-
块级作用域:ES6引入了let和const关键字,可以在块级作用域中声明变量,避免了变量提升和全局污染的问题。
-
箭头函数:箭头函数是一种更简洁的函数定义语法,可以减少代码量,并且自动绑定了this关键字,避免了传统函数中this指向问题的困扰。
-
模板字符串:模板字符串是一种更灵活的字符串拼接方式,可以通过
${}
语法插入变量和表达式,使代码更加清晰和易读。 -
解构赋值:解构赋值是一种通过模式匹配从数组或对象中提取值并赋给变量的方式,可以简化代码并提高可读性。
-
默认参数:ES6允许函数参数设置默认值,当调用函数时没有传入对应参数时,将使用默认值,提高了代码的灵活性和可维护性。
-
类和继承:ES6引入了class关键字,可以更方便地定义类和面向对象的编程。通过extends关键字,实现了类的继承,提供了更好的代码组织和复用。
-
Promise:Promise是一种处理异步操作的机制,可以更优雅地处理回调地狱问题,使异步代码更易读和维护。
-
模块化:ES6引入了模块化的概念,可以将代码分割成多个模块,每个模块可以导出(export)特定的函数、类、常量等,其他模块可以导入(import)这些导出的内容。模块化可以帮助我们更好地组织和管理代码。
除了上述特性,ES6还引入了许多其他的语法和功能,如迭代器、生成器、Set和Map数据结构、新的数组和字符串方法等,这些都为开发人员提供了更多的工具和选项来编写更高效和可维护的JavaScript代码。
下面代码详细说明
-
let和const:let和const是新的变量声明关键字。let声明的变量是块级作用域的,只在声明的块内有效。而const声明的变量是常量,一旦赋值就不能再改变。
-
箭头函数:箭头函数是一种新的函数声明方式。它可以简化函数的定义和调用,并且可以绑定this的值。箭头函数没有自己的this,它继承自外部作用域的this。例如:
const add = (a, b) => a + b;
console.log(add(1, 2)); // 输出3
- 模板字符串:模板字符串是一种新的字符串声明方式。它可以包含变量和表达式,并且支持多行字符串。模板字符串使用反引号(`)包裹,并且变量和表达式使用${}包裹。例如:
const name = 'Tom';
const message = `Hello, ${name}!
How are you today?`;
console.log(message);
- 解构赋值:解构赋值是一种新的变量赋值方式。它可以从数组或对象中提取值,并将其赋给变量。解构赋值使用方括号([])或花括号({})进行匹配。例如:
const [a, b, c] = [1, 2, 3];
console.log(a, b, c); // 输出1 2 3const {name, age} = {name: 'Tom', age: 20};
console.log(name, age); // 输出Tom 20
- 默认参数:默认参数是一种新的函数参数声明方式。它可以为函数参数设置默认值,如果调用函数时没有传递参数,则使用默认值。默认参数使用等号(=)进行赋值。例如:
function greet(name = 'Tom') {console.log(`Hello, ${name}!`);
}
greet(); // 输出Hello, Tom!
greet('Jerry'); // 输出Hello, Jerry!
- 扩展运算符:扩展运算符是一种新的运算符,它可以将数组或对象展开成多个参数或属性。扩展运算符使用三个点(…)进行展开。例如:
const arr1 = [1, 2, 3];
const arr2 = [4, 5, 6];
const arr3 = [...arr1, ...arr2];
console.log(arr3); // 输出[1, 2, 3, 4, 5, 6]const obj1 = {name: 'Tom', age: 20};
const obj2 = {gender: 'male', ...obj1};
console.log(obj2); // 输出{gender: 'male', name: 'Tom', age: 20}
- 类和继承:ES6引入了class关键字,可以用来定义类和继承关系。类可以包含构造函数、方法和属性。继承可以通过extends关键字实现。例如:
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('Rufus');
dog.speak(); // 输出Rufus barks.
- ES6模块化(Module):ES6引入了模块化的概念,可以将代码分割成多个模块,每个模块可以导出(export)特定的函数、类、常量等,其他模块可以导入(import)这些导出的内容。模块化可以帮助我们更好地组织和管理代码。例如:
// math.js
export function add(a, b) {return a + b;
}// main.js
import { add } from './math.js';
console.log(add(1, 2)); // 输出3
- extends关键字:extends关键字用于实现类的继承。通过extends关键字,一个类可以继承另一个类的属性和方法。继承可以帮助我们复用代码,并且可以实现更好的代码组织。例如:
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('Rufus');
dog.speak(); // 输出Rufus barks.
- 常量(const):const关键字用于声明常量,一旦赋值就不能再改变。常量可以保证变量的值不会被修改,避免了意外的错误。例如:
const PI = 3.14159;
console.log(PI); // 输出3.14159PI = 3.14; // 报错,常量的值不能被修改
- super关键字:super关键字用于调用父类的构造函数和方法。在子类的构造函数中,通过super关键字可以调用父类的构造函数,以初始化父类的属性。在子类的方法中,通过super关键字可以调用父类的方法。例如:
class Animal {constructor(name) {this.name = name;}speak() {console.log(`${this.name} makes a noise.`);}
}class Dog extends Animal {constructor(name) {super(name);}speak() {super.speak();console.log(`${this.name} barks.`);}
}const dog = new Dog('Rufus');
dog.speak();
// 输出:
// Rufus makes a noise.
// Rufus barks.
- Map(映射):Map是一种新的数据结构,它可以存储键值对,并且可以根据键获取值。与普通的对象相比,Map具有更好的性能和更丰富的功能。例如:
const map = new Map();
map.set('name', 'Tom');
map.set('age', 20);console.log(map.get('name')); // 输出Tom
console.log(map.has('age')); // 输出true
console.log(map.size); // 输出2map.delete('age');
console.log(map.size); // 输出1map.clear();
console.log(map.size); // 输出0
相关文章:
快速掌握ES6
什么是ES6 ES6(ECMAScript 6),也被称为ES2015,是JavaScript的第六个版本,于2015年发布。ES6引入了许多新的语法和功能,旨在提高JavaScript的开发效率和代码质量。 ES6的一些主要特性和改进包括࿱…...
电池厂提供excel电池曲线zcv到mtk电池曲线zcv转换
#encoding:utf8 #电池厂提供excel电池曲线zcv到mtk电池曲线zcv转换 import pandas as pd import openpyxl import math # 读取Excel文件 df pd.read_excel("a55-zcv.xlsx") for j in range(0,10): if(j<3): offset0 #T0~T2 if(j3): offset…...
重写和重载、抽象类和接口
文章目录 前言一、重载与重写1.重载(Overload)(1)条件(2)举例 2.重写(Override)(1)规则(2)举例 3.重载和重写区别 二、抽象类与接口1.抽象类&…...

Untiy UDP局域网 异步发送图片
同步画面有问题,传图片吧 using System.Text; using System.Net.Sockets; using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.Events; using System.Net; using System; using System.Threading.Tasks; using Sy…...

移动端H5封装一个 ScrollList 横向滚动列表组件,实现向左滑动
效果: 1.封装组件: <template><div class"scroll-list"><divclass"scroll-list-content":style"{ background, color, fontSize: size }"ref"scrollListContent"><div class"scroll…...
Docker一键安装和基本配置
一键安装脚本 注:该脚本需要root权限 curl -sSL https://get.docker.com/ | sh非root组用户赋权 sudo groupadd docker # 若使用一键安装脚本会自动创建这个组,提示已存在 sudo gpasswd -a ${USER} docker # 将当前用户添加到docker组,也…...

MVC设计思想理解和ASP.NET MVC理解
三层模式 三层模式包括:UI层,业务逻辑层,数据访问层,模型层 MVC设计思想和ASP.NET MVC理解 MVC设计思想: MVC的思想就是把我们的程序分为三个核心的模块,这三个模块的详细介绍如下: 模型(Model) :负责封装与引用程序的业务逻辑相关的数据以及对数据的处理方法。模型层有对…...

大模型应用选择对比
大模型应用选择对比 1、知识库对比:dify、fastgpt、langchatchat 2、agent构建器选择:flowise、langflow、bisheng 3、召回率提升方案...

c++STL概述
目录 STL基本概念 STL六大组件 STL的优点 STL三大组件 容器 算法 迭代器 普通的迭代器访问vector容器元素 算法for_each实现循环 迭代器指向的元素类型是自定义数据类型 迭代器指向容器 常用容器 string容器 string的基本概念 string容器的操作 string的构造函…...
利用容器技术优化DevOps流程
利用容器技术优化DevOps流程 随着云计算的快速发展,容器技术也日益流行。容器技术可以打包和分发应用程序,并实现快速部署和扩展。在DevOps流程中,容器技术可以大大优化开发、测试、部署和运维各个环节。本文将介绍如何利用容器技术优化DevO…...

91 # 实现 express 的优化处理
上一节实现 express 的请求处理,这一节来进行实现 express 的优化处理 让 layer 提供 match 方法去匹配 pathname,方便拓展让 layer 提供 handle_request 方法,方便拓展利用第三方库 methods 批量生成方法性能优化问题 进行路由懒加载&#…...

arcgis拓扑检查实现多个矢量数据之间消除重叠区域
目录 环境介绍: 操作任务: 步骤: 1、数据库和文件结构准备 2、建立拓扑规则 3、一直下一页默认参数后,进行拓扑检查 4、打开TP_CK_Topology,会自动带出拓扑要素,红色区域为拓扑错误的地方࿱…...

基于Vue+ELement搭建登陆注册页面实现后端交互
🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的专栏《ELement》。🎯🎯 …...
JS获取经纬度, 并根据经纬度得到城市信息
在JavaScript中,获取经纬度通常需要使用定位服务,比如HTML5的Geolocation API。然而拿到坐标后,将经纬度转换为城市信息,则需要使用逆地理编码服务接口,比如百度或者高德的 API, 但是他们收费都很高, 我们可以使用一些…...
mac m1 docker安装nacos
文章目录 引言I m1安装docker1.1 Docker 下载1.2 终端Docker相关命令II docker安装nacos2.1 安装nacos2.2 镜像启动see alsoMac 查看进程端口引言 使用docker方式安装是最方便的 I m1安装docker 1.1 Docker 下载 https://docs.docker.com/docker-for-mac/apple-silicon/点击…...

位段 联合体 枚举
Hello好久不见,今天分享的是接上次结构体没有分享完的内容,这次我们讲讲位段 枚举和联合体的概念以及他们的用法。 2.1 什么是位段 位段的声明和结构是类似的,有两个不同: 1.位段的成员必须是 int、unsigned int 或signed int 。 …...

PHP循环获取Excel表头字母A-Z,当超过时输出AA,AB,AC,AD······
PHP循环获取Excel表头字母A-Z,当超过时输出AA,AB,AC,AD PHP循环生成Excel的列字母表 $count_num 26 * 27; $letter A; $arr []; while($count_num--){$arr[] $letter;$letter; }结果如下: 转为JSON更为直观: ["A","B&…...

识别准确率达 95%,华能东方电厂财务机器人实践探索
摘 要:基于华能集团公司大数据与人工智能构想理念,结合东方电厂实际工作需要,财务工作要向数字化、智能化纵深推进,随着财务数字化转型和升级加速,信息化水平不断提升,以及内部信息互联互通不断加深&#x…...
代码随想录算法训练营 单调栈part03
一、柱状图中最大的矩形 84. 柱状图中最大的矩形 - 力扣(LeetCode) 单调栈很重要的性质,就是单调栈里的顺序,是从小到大还是从大到小。 栈顶和栈顶的下一个元素以及要入栈的三个元素组成了我们要求最大面积的高度和宽度&#x…...
使用 MyBatisPlus 的注解方式进行 SQL 查询,它结合了条件构造器(Wrapper)和自定义 SQL 片段来构建查询语句。
MyBatis-Plus 是一个基于 MyBatis 的增强工具,它提供了一套方便的注解方式来进行 SQL 查询。其中,它结合了条件构造器(Wrapper)和自定义 SQL 片段来构建查询语句。 官网:条件构造器 | MyBatis-Plus 1、使用 Wrapper …...
浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)
✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...

遍历 Map 类型集合的方法汇总
1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...

MMaDA: Multimodal Large Diffusion Language Models
CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构…...

如何在网页里填写 PDF 表格?
有时候,你可能希望用户能在你的网站上填写 PDF 表单。然而,这件事并不简单,因为 PDF 并不是一种原生的网页格式。虽然浏览器可以显示 PDF 文件,但原生并不支持编辑或填写它们。更糟的是,如果你想收集表单数据ÿ…...
探索Selenium:自动化测试的神奇钥匙
目录 一、Selenium 是什么1.1 定义与概念1.2 发展历程1.3 功能概述 二、Selenium 工作原理剖析2.1 架构组成2.2 工作流程2.3 通信机制 三、Selenium 的优势3.1 跨浏览器与平台支持3.2 丰富的语言支持3.3 强大的社区支持 四、Selenium 的应用场景4.1 Web 应用自动化测试4.2 数据…...

【若依】框架项目部署笔记
参考【SpringBoot】【Vue】项目部署_no main manifest attribute, in springboot-0.0.1-sn-CSDN博客 多一个redis安装 准备工作: 压缩包下载:http://download.redis.io/releases 1. 上传压缩包,并进入压缩包所在目录,解压到目标…...

归并排序:分治思想的高效排序
目录 基本原理 流程图解 实现方法 递归实现 非递归实现 演示过程 时间复杂度 基本原理 归并排序(Merge Sort)是一种基于分治思想的排序算法,由约翰冯诺伊曼在1945年提出。其核心思想包括: 分割(Divide):将待排序数组递归地分成两个子…...
python打卡第47天
昨天代码中注意力热图的部分顺移至今天 知识点回顾: 热力图 作业:对比不同卷积层热图可视化的结果 def visualize_attention_map(model, test_loader, device, class_names, num_samples3):"""可视化模型的注意力热力图,展示模…...
统计学(第8版)——统计抽样学习笔记(考试用)
一、统计抽样的核心内容与问题 研究内容 从总体中科学抽取样本的方法利用样本数据推断总体特征(均值、比率、总量)控制抽样误差与非抽样误差 解决的核心问题 在成本约束下,用少量样本准确推断总体特征量化估计结果的可靠性(置…...
WEB3全栈开发——面试专业技能点P8DevOps / 区块链部署
一、Hardhat / Foundry 进行合约部署 概念介绍 Hardhat 和 Foundry 都是以太坊智能合约开发的工具套件,支持合约的编译、测试和部署。 它们允许开发者在本地或测试网络快速开发智能合约,并部署到链上(测试网或主网)。 部署过程…...