JavaScript ES5到ES10新特性详解

ES5 (2009) - 现代JavaScript的基石

核心特性:

  • 严格模式 "use strict"

  • JSON对象支持 JSON.parse() 和 JSON.stringify()

  • 数组方法:forEachmapfilterreducesomeevery

  • 对象方法:Object.keys()Object.create()Object.defineProperty()

// ES5 数组方法示例var numbers = [1, 2, 3, 4, 5];var doubled = numbers.map(function(num) {    return num * 2;});console.log(doubled); // [2, 4, 6, 8, 10]

ES6 (2015) - 重大革新

核心特性:‌

let/const‌:块级作用域变量声明

箭头函数‌:() => {}

模板字符串‌:`Hello ${name}`

解构赋值‌:const {name, age} = person

类语法‌:class, extends, constructor

模块化‌:import/export

Promise‌:异步编程解决方案

默认参数‌和‌剩余参数

// ES6 类和解构示例class Person {    constructor(name, age) {        this.name = name;        this.age = age;    }        greet() {        return `Hello, I'm ${this.name}`;    }}const person = new Person('Alice', 25);const {name, age} = person;

ES7 (2016) - 简洁化增强

核心特性:‌

指数运算符‌:2 ** 3 // 8

Array.prototype.includes()‌:[1,2,3].includes(2) // true

// ES7 新特性const squared = 3 ** 2; // 9const hasValue = [1, 2, 3].includes(2); // true

ES8 (2017) - 异步革命

核心特性:‌

async/await‌:异步编程终极解决方案

Object.values()‌ 和 ‌Object.entries()‌

字符串填充‌:padStart(), padEnd()

** trailing commas**‌:函数参数尾随逗号

// ES8 async/await 示例async function fetchData() {    try {        const response = await fetch('/api/data');        const data = await response.json();        return data;    } catch (error) {        console.error('Fetch failed:', error);    }}// Object.entries() 示例const obj = {a: 1, b: 2};console.log(Object.entries(obj)); // [['a', 1], ['b', 2]]

ES9 (2018) - 异步迭代与Rest/Spread

核心特性:‌

异步迭代‌:for await...of

Promise.finally()‌:无论成功失败都会执行

Rest/Spread 属性‌:对象解构

// ES9 异步迭代async function processArray(array) {    for await (let item of array) {        console.log(item);    }}// Promise.finally()fetch('/api/data')    .then(data => console.log(data))    .catch(error => console.error(error))    .finally(() => console.log('Request completed'));

ES10 (2019) - 稳定与优化

核心特性:‌

Array.flat()‌ 和 ‌Array.flatMap()‌:数组扁平化

Object.fromEntries()‌:键值对数组转对象

String.trimStart()‌ 和 ‌String.trimEnd()‌

可选catch绑定‌:try {} catch {}

// ES10 数组扁平化const nestedArray = [1, [2, [3, [4]]]];const flatArray = nestedArray.flat(2); // [1, 2, 3, [4]]// Object.fromEntries()const entries = [['name', 'Alice'], ['age', 25]];const person = Object.fromEntries(entries);

实际应用示例

以下是一个综合使用各版本特性的完整示例:

// ES6+ 综合示例class ApiService {    static baseURL = 'https://api.example.com';        constructor(token) {        this.token = token;    }        async fetchUserData(userId) {        try {            const response = await fetch(`${ApiService.baseURL}/users/${userId}`, {                headers: {                    'Authorization': `Bearer ${this.token}`                }            });                        if (!response.ok) {                throw new Error(`HTTP error! status: ${response.status}`);            }                        const userData = await response.json();            const {name, email, ...otherInfo} = userData;                        return {                name: name?.trim() ?? 'Unknown',                email: email?.toLowerCase(),                ...otherInfo            };        } catch (error) {            console.error('Failed to fetch user:', error);            return null;        }    }}// 使用示例const api = new ApiService('your-token');const user = await api.fetchUserData(123);

浏览器兼容性建议

‌生产环境建议:‌

使用Babel转译ES6+代码

配置合适的polyfill

考虑使用TypeScript获得更好的类型支持

这些新特性极大地提升了JavaScript的开发体验和代码质量,建议根据项目需求选择合适的特性组合使用。


标签:

相关文章

国庆节快乐

在这个特殊的日子里,让我们共同庆祝中华人民共和国的生日。红旗飘扬在空中,礼炮声回荡在城市中,举国欢庆。我们爱我们的国家,因为它是我们温暖的家园,我们成长的摇篮。国庆节是我国的法定节假日,这是一个金色的...

甘草露,甘草露,清凉的甘草露

我知道,那是在七月,骄阳似火,百叶窗紧闭的大卧室里一片昏暗。当他慢慢地、静静地咽气时,在那炎热的夏日午后令人窒息的宁静中,忽然街上传来清脆的铃声,一个响亮的声音划破闷人的溽暑,喊道:“清凉的甘草露!太...

海量数据分布式处理

若数据量达到 ‌千万级或 TB 级‌,可结合消息队列(如 RabbitMQ、Kafka)实现分布式消费:// 生产者:将数据分块推送至队列 $redis = new&n...

UniApp 导航栏全面指南

UniApp 作为跨平台开发框架,其导航栏的实现与配置是开发中的关键环节。本指南将全面介绍 UniApp 导航栏的配置方法、自定义实现、多平台适配策略以及性能优化方案。一、基础配置与原生导航栏1. 全...

前端开发的核心常识总结

一、前端开发的定义与职责前端开发指构建用户直接交互的网页或应用界面,通过HTML、CSS、JavaScript等技术实现视觉呈现、交互逻辑和数据处理。核心目标是为用户提供流畅、直观的体验‌主要职责包括...

uniapp结合vue3的开发指南和技术要点

一、项目创建与配置环境要求:需Node.js 18+/20+版本,推荐使用Vite构建工具创建命令:npx degit dcloudio/uni-preset-vue#vite-t...