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

品牌查询网站移动网站开发面试

品牌查询网站,移动网站开发面试,wps2016怎么做网站,建设机械网站方案设计一、ECMAScript 概述 1. 什么是 ECMA ECMA(European Computer Manufacturers Association)中文名称为欧洲计算机制造商协会,这个组织的目标是评估、开发和认可电信和计算机标准。1994年后该组织改名为 Ecma 国际。 2. 什么是 ECMAScript …

一、ECMAScript 概述

1. 什么是 ECMA

ECMA(European Computer Manufacturers Association)中文名称为欧洲计算机制造商协会,这个组织的目标是评估、开发和认可电信和计算机标准。1994年后该组织改名为 Ecma 国际。

2. 什么是 ECMAScript

ECMAScript 是由 Ecma 国际通过 ECMA-262 标准化的脚本程序设计语言。ECMAScript 和 JavaScript 的关系是:前者是后者的规格,后者是前者的一种实现(另外的 ECMAScript 方言还有 JScript 和 ActionScript)。日常场合,这两个词是可以互换的。

3. ECMA-262 历史

  • ES1 (1997): 制定了语言的基本语法

  • ES2 (1998): 较小改动

  • ES3 (1999): 引入正则、异常处理、格式化输出等

  • ES4 (2007): 过于激进,未发布

  • ES5 (2009): 引入严格模式、JSON,扩展对象、数组、原型、字符串、日期方法

  • ES6/ES2015 (2015): 模块化、面向对象语法、Promise、箭头函数、let、const等

  • 从 ES6 开始,每年发布一个版本,版本号比年份最后一位大 1

二、ES6 (ES2015) 核心特性

1. let 和 const 声明

// let 特性
let a = 1;
// 1. 不允许重复声明
// let a = 2; // 报错
// 2. 块级作用域
{let b = 2;
}
// console.log(b); // 报错
// 3. 不存在变量提升
// console.log(c); // 报错
let c = 3;// const 特性
const PI = 3.14;
// PI = 3.1415; // 报错
// 但对于对象和数组,内容可以修改
const obj = {a: 1};
obj.a = 2; // 允许

2. 解构赋值

// 数组解构
let [x, y] = [1, 2];// 对象解构
let {name, age} = {name: '张三', age: 20};// 函数参数解构
function foo({x, y}) {console.log(x, y);
}
foo({x: 1, y: 2});

3. 模板字符串

let name = '李四';
let str = `你好,${name}!
欢迎来到ES6的世界。`;

4. 箭头函数

// 简化写法
const sum = (a, b) => a + b;// this 绑定
const obj = {value: 1,getValue: function() {setTimeout(() => {console.log(this.value); // 1}, 100);}
};

5. 函数参数默认值

function greet(name = '匿名') {console.log(`你好,${name}`);
}

6. 扩展运算符和 rest 参数

// 扩展运算符
let arr1 = [1, 2];
let arr2 = [...arr1, 3, 4]; // [1, 2, 3, 4]// rest 参数
function sum(...numbers) {return numbers.reduce((a, b) => a + b);
}

7. Symbol 类型

const sym1 = Symbol('key');
const sym2 = Symbol('key');
console.log(sym1 === sym2); // false

8. Promise

const promise = new Promise((resolve, reject) => {setTimeout(() => resolve('成功'), 1000);
});promise.then(value => console.log(value));

9. Set 和 Map

// Set
let set = new Set([1, 2, 3, 3]);
console.log(set.size); // 3// Map
let map = new Map();
map.set('name', '张三');

10. Class 类

class Person {constructor(name) {this.name = name;}sayHello() {console.log(`你好,我是${this.name}`);}
}

11. 模块化

// math.js
export function add(a, b) { return a + b; }// app.js
import { add } from './math.js';

三、ES2016 新特性

1. Array.prototype.includes

[1, 2, 3].includes(2); // true

2. 指数运算符

2 ** 3; // 8

四、ES2017 新特性

1. async/await

async function fetchData() {const response = await fetch('api/data');const data = await response.json();return data;
}

2. Object.values/Object.entries

const obj = {a: 1, b: 2};
Object.values(obj); // [1, 2]
Object.entries(obj); // [['a', 1], ['b', 2]]

五、ES2018 新特性

1. 对象 rest/spread

const obj = {a: 1, b: 2, c: 3};
const {a, ...rest} = obj; // rest = {b: 2, c: 3}
const newObj = {...obj, d: 4};

2. 正则表达式命名捕获组

const re = /(?<year>\d{4})-(?<month>\d{2})/;
const match = re.exec('2023-05');
match.groups.year; // "2023"

六、ES2019 新特性

1. Array.prototype.flat/flatMap

[1, [2, [3]]].flat(2); // [1, 2, 3]
[1, 2].flatMap(x => [x, x*2]); // [1, 2, 2, 4]

2. Object.fromEntries

const entries = [['a', 1], ['b', 2]];
Object.fromEntries(entries); // {a: 1, b: 2}

七、ES2020 新特性

1. 可选链操作符

const street = user?.address?.street;

2. 空值合并运算符

const name = user.name ?? '匿名';

3. Promise.allSettled

Promise.allSettled([promise1, promise2]).then(results => console.log(results));

八、ES2021 新特性

1. String.prototype.replaceAll

'hello world'.replaceAll('l', 'L'); // "heLLo worLd"

2. 逻辑赋值运算符

a ||= b; // a = a || b
a &&= b; // a = a && b
a ??= b; // a = a ?? b

九、ES2022 新特性

1. 顶层 await

// 模块顶层可以直接使用 await
const response = await fetch('api/data');

2. 类静态块

class C {static {// 类初始化代码}
}

十、ES2023 新特性

1. Array.prototype.findLast/findLastIndex

[1, 2, 3, 2].findLast(x => x === 2); // 2

十一、ES2024 新特性

1. 原生数组分组

const groups = Object.groupBy(items, item => item.category);

2. Promise.withResolvers

const { promise, resolve, reject } = Promise.withResolvers();

总结

从 ES6 到 ES2024,JavaScript 语言经历了巨大的变革和发展。这些新特性极大地提升了开发效率、代码可读性和维护性。作为现代 JavaScript 开发者,掌握这些特性是必不可少的技能。建议在实际项目中逐步尝试使用这些新特性,同时注意浏览器和运行环境的兼容性问题。


文章转载自:

http://RDCNtvro.yrwqz.cn
http://MCXyBJdx.yrwqz.cn
http://sBMBPeV0.yrwqz.cn
http://apqkYrbI.yrwqz.cn
http://wjY2kxKs.yrwqz.cn
http://o4BshMAB.yrwqz.cn
http://0MeA3CNm.yrwqz.cn
http://BKfIOhOk.yrwqz.cn
http://taD8rN9l.yrwqz.cn
http://GD8QqoTS.yrwqz.cn
http://pZHRd9qx.yrwqz.cn
http://DQaTLByE.yrwqz.cn
http://J141BCiH.yrwqz.cn
http://mCbdR6Jo.yrwqz.cn
http://CcqdtaWB.yrwqz.cn
http://xpKtCXsM.yrwqz.cn
http://IZttxelL.yrwqz.cn
http://Kg5UtSoo.yrwqz.cn
http://Le2fTI0S.yrwqz.cn
http://gqzV4xr0.yrwqz.cn
http://R4weQNQB.yrwqz.cn
http://QM6dix7X.yrwqz.cn
http://7vUr6sSS.yrwqz.cn
http://B7CfLhte.yrwqz.cn
http://CVxdrVEi.yrwqz.cn
http://aBNMeEtZ.yrwqz.cn
http://5fPLJHBq.yrwqz.cn
http://h1ycypp7.yrwqz.cn
http://zozmapqS.yrwqz.cn
http://dcAIOWkQ.yrwqz.cn
http://www.dtcms.com/wzjs/713416.html

相关文章:

  • 织梦cms怎样做网站成都网站建设排行榜
  • 腾讯wordpress 建站教程企业网站推广建议
  • 勉费申请做网站最新黑帽seo教程
  • 重庆 建站 价格重庆网上房地产官网查询
  • 网站建设应遵循的原则影视后期制作培训机构全国排名
  • 电子商务网站网站建设广东建设厅官网证件查询
  • 东营市城乡建设局网站wordpress 搬家后图片不显示
  • 艺术毕业设计作品网站怎么做网站结构拓扑图
  • 建设银行科技中心网站站长查询站长工具
  • 泉州工作室网站建设做同城特价的网站有哪些
  • 网站后端用什么软件做网站建设一条龙全包顶呱呱
  • 徐州网站关键词推广网络设计与制作是什么意思
  • wordpress怎么在底部调用友情链接广州网站优化关键词方法
  • 网站维护客户手机网站怎么搭建
  • 响应式网站 图片居中电子书籍网站开发
  • 微信网站开发系统app网站开发案例
  • 滁州seo网站推广方案四川seo整站优化吧
  • 免费个人网站建设公司网站后台管理系统背景图片
  • 网站开发用什么开发工具好呢芙蓉区网站建设
  • 网站开发职位工资家在深圳光明
  • 深圳宝安网站建设工建站之星多语言
  • 做吃的网站自己做的网站别人怎么访问
  • 福建龙泉建设有限公司网站做招聘的网站有哪些内容
  • 拼多多网站建设合同做内部优惠券网站赚钱吗
  • 中山 网站制作专业网站建设人工智能研发
  • 商城类网站功能西安维护网站
  • 简述企业网站建设的目的百度推广手机app下载
  • 做网站的版式会侵权吗吉安市城乡建设局网站
  • 漳州市东山县建设局网站苏州企业网站建设设计
  • 网站关键词快速排名服务如何创建网站的详细步骤