js版本ES6、ES7、ES8、ES9、ES10、ES11、ES12、ES13、ES14[2023]新特性

ES全称ECMAScript,ECMAScript是ECMA制定的标准化脚本语言,本文讲述Javascript[ECMAScript]版本ES6、ES7、ES8、ES9、ES10、ES11、ES12、ES13、ES14[2023]的新特性,帮助朋友们更好的熟悉和使用Javascript

ES5

1.严格模式

use strict

2.Object

   getPrototypeOf,返回一个对象的原型getOwnPropertyDescriptor,返回某个对象自有属性的属性描述符getOwnPropertyNames,返回一个数组,包括对象所有自由属性名称集合(包括不可枚举的属性)hasOwnProperty,给定属性存在于对象实例中,返回 trueisPrototypeOf,在原型链中出现过的原型,返回 truecreate,创建一个拥有指定原型和若干指定属性的对象defineProperty,为对象定义一个新属性,或者修改已有的属性,并对属性重新设置 getter 和 setter,这里可以被用作数据绑定的对象劫持用途defineProperties,在一个对象上添加或修改一个或者多个自有属性,与 defineProperty 类似seal,锁定对象,阻止修改现有属性的特性,并阻止添加新属性,但是可以修改已有属性的值freeze,冻结对象,阻止对对象的一切操作和更改,冻结对象将变成只读preventExtensions,让一个对象变得不可以扩展,也就是不能再添加新的属性isSealed,判断对象是否被锁定isFrozen,判断对象是否被冻结isExtensible,判断对象是否可以被扩展keys,返回一个由给定对象的所有可以枚举自身属性的属性名组成的数组

3.Array

Array.isArray,确定某个值到底是不是数组,不管它在哪个全局执行环境中创建push,接收任意数量的参数,把它们逐个添加到数组末尾,并返回修改后数组的长度pop,在数组尾部移除最后一项,减少数组的 length 值,然后返回移除的项shift,移除数组中的第一项并返回该项,同时将数组长度减 1unshift,在数组前端添加任意个项,并返回新数组的长度reverse,反转数组项的顺序,返回排序后的数组sort,默认情况下,按升序排序数组项,返回排序后的数组concat,创建当前数组的一个副本,将接收到的参数添加到这个副本的末尾,返回新构建的数组join,用指定的字符拼接数组,返回拼接好的字符串slice,基于当前数组中的一个或多个创建一个新数组,不影响原始数组splice,根据传入参数不同,可以删除、插入、替换数组元素,返回一个数组,该数组中包含从原始数组中删除的项,如果没有删除任何项,则返回空数组indexOf,返回根据给定元素找到的第一个索引值,如果不存在则返回 -1lastIndexOf,返回指定元素在数组中的最后一个索引值,如果不存在则返回 -1every ,对数组中的每一项运行给定函数 ,如果该函数对每一项都返回 true,则返回 truefilter,对数组中的每一项运行给定函数 ,返回该函数会返回 true 的项组成的数组forEach,对数组中的每一项运行给定函数,没有返回值map,对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组some,对数组中的每一项运行给定函数,如果函数对任一项返回 true,则返回 truereduce,接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终缩减为一个值reduceRight,接收一个函数作为累加器,数组中的每个值(从右到左)开始缩减,最终缩减为一个值

4.String

charAt,访问字符串中特定字符,返回给定位置的字符charCodeAt,访问字符串中特定字符,返回给定位置的字符的字符编码concat,将一个或多个字符串拼接起来,返回拼接得到的新字符串match,查找匹配的字符串,返回一个数组search,查找匹配的字符串,返回匹配项的索引,没有找到,返回 -1replace,替换字符串split,基于指定的分隔符将一个字符串分割成多个字符串,将结果放在一个数组中,并返回trim,创建一个字符串的副本,删除前置及后缀的所有空格,然后返回结果localeCompare,比较两个字符串slice,返回被操作字符串的一个子字符串substr,返回被操作字符串的一个子字符串substring,返回被操作字符串的一个子字符串

注意:slice、substr、substring 都接受一个或两个参数,第一个参数指定字符串的开始位置,第二个参数表示子字符串到哪里结束,slice 和 substring 的第二个参数指定的是子字符串的最后一个字符后面的位置,substr 第二个参数指定的是返回的字符个数,如果没有传递第二个参数,则将字符串的末尾作为结束位置。

5.Function

 	arguments.callee,该属性是一个指针,指向拥有这个 arguments 对象的函数arguments.caller,该属性保存着调用当前函数的函数的引用apply,在特定的作用域中调用函数,第一个参数是在其中运行函数的作用域,第二个是参数数组call,在特定的作用域中调用函数,第一个参数是在其中运行函数的作用域,其余参数直接传递给函数bind,创建一个函数的实例,其 this 值会被绑定到传给 bind 函数的值

6.JSON

	JSON.parse,解析字符串为 JSON 对象JSON.stringify,解析 JSON 对象为字符串JSON.valueOf,获取某个JSON 对象中的值JSON.toString,被调用时,会调用 Object 原型上的 toString 方法,会获的 JSON 对象的值并转为字符串,如果没有具体的值,则返回原型数组JSON.toLocaleString,也是Object 原型上的方法,经常会返回与 toString 相同内容,但是对于 Date 对象,则会返回格式化的时间字符串

7.其他

  Date.now,返回当前时间戳Date.toJSON,将 Date 对象转换为字符串,格式为 JSON 日期Math.min,确定一组数值中的最小值Math.max,确定一组数值中的最大值Math.random,返回大于 0 小于 1 的一个随机数Number.prototype.toFixed,按照指定的小数位返回数值的字符串表示

ES6(2015)

1.类

class Man {constructor(name) {this.name = '你好世界';}console() {console.log(this.name);}
}
const man = new Man('你好世界');
man.console(); // 你好世界
创建类的几种方法:在 JavaScript 中,创建类有几种不同的方式。以下是几种常见的方法:
1. 使用 class 关键字(ES6+)这是 ES6 引入的一种标准语法来创建类,语法简洁易懂。javascript
class Person {constructor(name, age) {this.name = name;this.age = age;}greet() {console.log(`Hello, my name is ${this.name} and I am ${this.age} years old.`);}
}const person = new Person('Alice', 30);
person.greet();  // 输出: Hello, my name is Alice and I am 30 years old.2. 使用函数构造器(传统方式)在 ES6 之前,使用函数构造器来模拟类。函数构造器通过 new 关键字来创建实例,并通过原型链定义方法。javascript
function Person(name, age) {this.name = name;this.age = age;
}Person.prototype.greet = function() {console.log(`Hello, my name is ${this.name} and I am ${this.age} years old.`);
};const person = new Person('Bob', 25);
person.greet();  // 输出: Hello, my name is Bob and I am 25 years old.3. 使用 Object.create() 和构造函数通过 Object.create() 可以创建一个对象并设置它的原型,进而模拟类的行为。javascript
const PersonPrototype = {greet: function() {console.log(`Hello, my name is ${this.name} and I am ${this.age} years old.`);}
};function Person(name, age) {const obj = Object.create(PersonPrototype);obj.name = name;obj.age = age;return obj;
}const person = Person('Charlie', 40);
person.greet();  // 输出: Hello, my name is Charlie and I am 40 years old.4. 使用 class 和继承(ES6+)ES6 的 class 语法支持继承,可以通过 extends 关键字来实现。javascript
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('Rex');
dog.speak();  // 输出: Rex barks.5. 使用 ES6 class 和静态方法class 还支持静态方法,这些方法不会被实例化,而是直接在类本身上调用。javascript
class Calculator {static add(a, b) {return a + b;}static subtract(a, b) {return a - b;}
}console.log(Calculator.add(5, 3));  // 输出: 8
console.log(Calculator.subtract(5, 3));  // 输出: 26. 使用 ES5 构造函数结合原型链和静态方法在传统的 ES5 中,也可以通过原型链结合静态方法来模拟类的功能。function Car(make, model) {this.make = make;this.model = model;
}Car.prototype.drive = function() {console.log(`${this.make} ${this.model} is driving.`);
};Car.getBrand = function() {return 'Generic Car Brand';
};const car = new Car('Toyota', 'Camry');
car.drive();  // 输出: Toyota Camry is driving.
console.log(Car.getBrand());  // 输出: Generic Car Brand

2.模块化(ES Module)

// 模块 A 导出一个方法
export const sub = (a, b) => a + b;
// 模块 B 导入使用
import { sub } from './A';
console.log(sub(1, 2)); // 3

3.箭头(Arrow)函数

const func = (a, b) => a + b;
func(1, 2); // 3箭头函数(Arrow Function)是 JavaScript 中一种简化函数写法的语法,它使用 => 符号来定义函数。箭头函数提供了一种更简洁的方式来定义匿名函数,同时也改变了 this 关键字的行为。
基本语法javascript
const functionName = (parameters) => {// 函数体
};示例
1. 简单的箭头函数javascript
const add = (a, b) => {return a + b;
};console.log(add(2, 3));  // 输出: 52. 单行箭头函数(隐式返回)如果箭头函数的主体只有一个表达式,可以省略 return 关键字,并且该表达式的值会被自动返回。javascript
const add = (a, b) => a + b;console.log(add(2, 3));  // 输出: 53. 无参数的箭头函数如果没有参数,仍然需要一个空的括号。javascript
const greet = () => console.log('Hello!');greet();  // 输出: Hello!4. 只有一个参数的箭头函数如果函数只有一个参数,可以省略括号。javascript
const square = x => x * x;console.log(square(5));  // 输出: 25箭头函数的特点
1. this 绑定箭头函数最显著的特点是它不会创建自己的 this,而是继承外部上下文中的 this。这意味着箭头函数中的 this 与外部的 this 相同,而常规函数会根据调用的上下文来决定 this。javascript
// 使用常规函数时,`this` 指向的是调用函数的对象
function Person(name) {this.name = name;
}Person.prototype.greet = function() {console.log(`Hello, ${this.name}`);
};const john = new Person('John');
john.greet();  // 输出: Hello, John// 使用箭头函数时,`this` 继承自外部环境
function Person(name) {this.name = name;setTimeout(() => {console.log(`Hello, ${this.name}`);}, 1000<

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

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

相关文章

Redis数据结构-String字符串

1.String字符串 字符串类型是Redis中最基础的数据结构&#xff0c;关于数据结构与要特别注意的是&#xff1a;首先Redis中所有的键的类型都是字符串类型&#xff0c;而且其他集中数据结构也都是在字符串类似基础上进行构建&#xff0c;例如列表和集合的元素类型是字符串类型&a…

cline通过硅基流动平台接入DeepSeek-R1模型接入指南

为帮助您更高效、安全地通过硅基流动平台接入DeepSeek-R1模型&#xff0c;以下为优化后的接入方案&#xff1a; DeepSeek-R1硅基流动平台接入指南 &#x1f4cc; 核心优势 成本低廉&#xff1a;注册即送2000万Tokens&#xff08;价值约14元&#xff09;高可用性&#xff1a;规…

Java多线程三:补充知识

精心整理了最新的面试资料&#xff0c;有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 Lambda表达式 简介&#xff1a; 希腊字母表中排序第十一位的字母&#xff0c;英语名称为Lambda避免匿名内部类定义过多其实质属于函数式编程的概念 为什么要使用lam…

装修流程图: 装修前准备 → 设计阶段 → 施工阶段 → 安装阶段 → 收尾阶段 → 入住

文章目录 引言I 毛坯房装修的全流程**1. 装修前准备****1.1 确定装修预算****1.2 选择装修方式****1.3 选择装修公司****1.4 办理装修手续****2. 设计阶段****2.1 量房****2.2 设计方案****2.3 确认方案****3. 施工阶段****3.1 主体拆改****3.2 水电改造****3.3 防水工程****3.…

Embedding方法:从Word2Vec到ltem2Vec

引言 在推荐系统领域&#xff0c;如何有效表征物品特征始终是核心挑战。传统协同过滤方法受限于稀疏性问题&#xff0c;直到2016年微软研究院提出的Item2Vec方法&#xff0c;将自然语言处理中的Word2Vec技术创造性应用于物品表征学习&#xff0c;开启了嵌入学习的新纪元。 It…

Udp发送和接收数据(python和QT)

服务端代码 (python) import socketdef udp_server(host0.0.0.0, port12345):# 创建一个UDP套接字sock socket.socket(socket.AF_INET, socket.SOCK_DGRAM)# 绑定服务器的IP地址和端口号sock.bind((host, port))print(f"UDP服务器已启动&#xff0c;监听端口 {port}...&…

VBA脚本将DeepSeek嵌入Word中教程

一、获取API-Key 目前我们可以直接只用官网的API来实现&#xff0c;申请这一步是关键 也可以直接访问官网的API平台&#xff1a;https://platform.deepseek.com/ &#xff0c;没注册的注册完登录一下&#xff0c;我们点击到左侧菜单的“APIKeys”按钮&#xff0c;然后点击右侧…

DeepSeek接入Siri(已升级支持苹果手表)完整版硅基流动DeepSeek-R1部署

DeepSeek接入Siri&#xff08;已升级支持苹果手表&#xff09;完整版硅基流动DeepSeek-R1部署 **DeepSeek** 是一款专注于深度学习和人工智能的工具或平台&#xff0c;通常与人工智能、机器学习、自动化分析等领域有关。它的主要功能可能包括&#xff1a;深度学习模型搜索&…

网站搭建基本流程

需求分析&#xff1a; 实现网站搭建的过程&#xff1a;首先进行网站的需求性分析 网站可分为前台系统和后台系统&#xff0c;由不同的功能拆分为不同的模块 如下是一个电商网站可以拆分出的模块&#xff1a; 在编写代码前&#xff0c;我们要先对网站进行架构&#xff0c;通过…

解决elementUi el-select 响应式不生效的问题

情况一,字段类型不匹配 考虑option的value值的字段类型是否和api返回的字段类型一致&#xff0c;如果一个为字符串一个为数字类型是无法匹配上的 <template> <div><el-select v-model"value" size"large"style"width: 240px"&…

QT实战-基于QWidget实现的异形tip窗口

本文主要介绍了qt中,基于QWidget实现异形tip窗口的几种实现方式,话不多说,先上图, 1.使用QPainter和QPainterPath实现 代码:tipwnd1.h #ifndef TIPWND1_H #define TIPWND1_H#include <QWidget>class TipWnd1 : public QWidget {Q_OBJECTQ_PROPERTY(QColor my_border…

【C++篇】树影摇曳,旋转无声:探寻AVL树的平衡之道

文章目录 从结构到操作&#xff1a;手撕AVL树的实现一、AVL树介绍1.1 什么是AVL树1.2 平衡因子的定义1.3 平衡的意义1.4 AVL树的操作 二、AVL树的节点结构2.1 节点结构的定义&#xff1a; 三、插入操作3.1 插入操作概述3.2 步骤1&#xff1a;按二叉查找树规则插入节点3.3 步骤2…

么是静态住宅IP,跨境电商为什么需要静态住宅IP

静态住宅IP是指直接分配给一台属于私人住宅网络的设备的固定IP地址&#xff0c;这种地址不会频繁更改。它们作为代理IP&#xff0c;使使用者能够通过这些代理服务器进行网络访问&#xff0c;而对外显示的则是该住宅的IP地址。由于这些IP地址属于真实的住宅或个人&#xff0c;并…

清华大学deepseek教程第四版 DeepSeek+DeepResearch 让科研像聊天一样简单(附下载)

deepseek使用教程系列 DeepSeekDeepResearch 让科研像聊天一样简单(附下载) https://pan.baidu.com/s/1VMgRmCSEzNvhLZQc8mu6iQ?pwd1234 提取码: 1234 或 https://pan.quark.cn/s/f3d4511b790a

leetcode刷题记录(一百零七)——279. 完全平方数

&#xff08;一&#xff09;问题描述 279. 完全平方数 - 力扣&#xff08;LeetCode&#xff09;279. 完全平方数 - 给你一个整数 n &#xff0c;返回 和为 n 的完全平方数的最少数量 。完全平方数 是一个整数&#xff0c;其值等于另一个整数的平方&#xff1b;换句话说&#x…

软考高级信息系统项目管理师笔记-第2章信息技术发展

第2章 信息技术发展 2.1 信息技术及其发展 1、按表现形态的不同,信息技术可分为硬技术(物化技术)与软技术(非物化技术)。前者指各种信息设备及其功 能,如传感器、服务器、智能手机、通信卫星、笔记本电脑。后者指有关信息获取与处理的各种知识、方法 与技能,如语言文字…

搭建RAG知识库的完整源码实现

搭建RAG知识库的完整源码实现&#xff08;基于Python 3.8&#xff09;&#xff1a; # -*- coding: utf-8 -*- # 文件名&#xff1a;rag_knowledge_base.py # RAG知识库搭建完整源码&#xff08;含中文注释&#xff09;import os import re import shutil import chromadb from…

利用AFE+MCU构建电池管理系统(BMS)

前言 实际BMS项目中&#xff0c;可能会综合考虑成本、可拓展、通信交互等&#xff0c;用AFE&#xff08;模拟前端&#xff09;MCU&#xff08;微控制器&#xff09;实现BMS&#xff08;电池管理系统&#xff09;。 希望看到这篇博客的朋友能指出错误或提供改进建议。 有纰漏…

基于SpringBoot的智慧家政服务平台系统设计与实现的设计与实现(源码+SQL脚本+LW+部署讲解等)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

什么是 Cloud Studio DeepSeek ; 怎么实现Open WebUI快速体验

什么是 Cloud Studio DeepSeek ;怎么实现Open WebUI快速体验 一、概述 欢迎使用 Cloud Studio DeepSeek 工作空间!我们已为您预装并启动了以下服务,等待加载十几秒即可查看效果: Ollama 服务:支持通过 API 调用 DeepSeek 模型。 AnythingLLM 前端服务:提供交互式聊天界…