7个新的ES2022 JavaScript 功能,你千万不要错过了
创始人
2024-02-22 13:23:29
0

这些功能已经发布了一段时间,现在让我们一起来看一下!

1.私有字段

以前,必须在构造函数中定义所有类字段。而且没有私人领域, 所有字段都可以从外部访问。当然,有一些技巧范围使一些变量无法访问。但是,让我们不要谈论他们。

class Counter {  constructor() {    this.name = 'Counter';    this.count = 0;  }
  inc() {    this.count++;  }}

现在我们可以简单地写:

class Counter {  name = 'Counter';  #count = 0;  // private field!  inc() {    this.#count++;  }}

2.使用关键字检查访问私有字段

私人领域带来了一些问题。当在没有该对象上访问私有字段时,将抛出错误。但是如何检查对象是否有?使用尝试/捕获!

现在有一个更好的方法:in关键字中。

class Counter {  name = 'Counter';  #count = 0;static isCounter(obj) {    return #count in obj;  }}const counter = new Counter();Counter.isCounter(counter);   // true

3. at()方法的数组和字符串

我们可以通过编写[i]来访问位置A[i]的数组的项目。但是,如果我是负的,并且我们想从数组的末端获得元素怎么办?我们可以编写[a.length + i]。但这不是很方便。另一种方法是使用A.slice(i)[0]。但这不是很有效。

为此有at()方法:

const A = [2, 4, 6, 8, 10]A.at(-1)    // 10const S = "Hello World"S.at(-1)    // 'd'

4.使用 findLast() 从数组的末尾开始查找一个项目

如何在数组中找到一个项目?使用find()方法。以及如何从最后找到?使用reverse()和find(),或者编写自己的函数:

const A = [1, 20, 3, 40, 5];function findBackward(A, predicate) {  for (let i = A.length-1; i>=0; i--) {    if (predicate(A[i])) {      return A[i];    }  }  return -1;}findBackward(A, x => x % 10 == 0);    // 40// be careful with this method!A.reverse().find(x => x % 10 == 0);   // 40

现在,我们可以使用Findlast()和FindlastIndex()方法:

const A = [1, 20, 3, 40, 5];A.find(v => v%10 == 0)     // 20A.findLast(v => v%10 == 0) // 40A.findIndex(v => v%10 == 0)     // 1A.findLastIndex(v => v%10 == 0) // 3A.findLastIndex(v => v == 0)    // -1

5.让我们使用Hasown()而不是HasownProperty()

有object.prototype.hasownproperty()方法来检查对象是否具有属性为其直接属性。但是使用很麻烦:

let hasOwnProperty = Object.prototype.hasOwnProperty;if (hasOwnProperty.call(object, 'foo')) {  console.log('has property foo');}

但是,我们现在可以这样写:

object.hasOwnProperty('foo')

请记住,JavaScript是一种动态语言。我们可以将属性添加到任何对象。因此,HasownProperty()可以被具有相同名称的对象的属性遮蔽。为了避免这种情况,我们可以使用Hasown()方法:

if (Object.hasOwn(object, 'foo')) {  console.log('has property foo');}

6.原因是一个错误的新属性

看到这样的错误处理代码非常常见:

await fetch('https://example.com/data.csv')  .catch((err) => {     throw new Error('failed to get: ' + err.message);  })

它的作用是将原始错误用新错误包裹,但是原始错误丢失了。现在,我们可以使用原因属性存储原始错误并稍后检索:

await fetch('https://example.com/data.csv')  .catch((err) => {     throw new Error('failed to get', { cause: err })  })  .catch((err) => {     console.log('cause', err.cause)  })

7.#!Hashbang现在得到支持

Hashbang现在得到了支持, 我们可以直接在终端运行nodejs脚本:

#!/usr/bin/env node'use strict';console.log(1);

或者:

#!/usr/bin/env nodeexport {};console.log(1);

总结

以上就是我今天与你分享的7个有关ES2022的新功能,希望对你有所帮助,也希望你能从中学到新的知识。

相关内容

热门资讯

东方电子跌2.04%,成交额7... 5月14日,东方电子盘中下跌2.04%,截至11:00,报9.59元/股,成交7109.97万元,换...
龙利得涨2.30%,成交额24... 5月14日,龙利得盘中上涨2.30%,截至10:59,报5.79元/股,成交2494.39万元,换手...
国台办回应民进党当局加紧采购爱... 转自:财联社【国台办回应民进党当局加紧采购爱国者导弹】财联社5月14日电,国台办举行例行新闻发布会。...
格林精密跌2.04%,成交额5... 5月14日,格林精密盘中下跌2.04%,截至11:00,报14.92元/股,成交5458.96万元,...
晶华微跌2.06%,成交额17... 5月14日,晶华微(维权)盘中下跌2.06%,截至10:50,报25.66元/股,成交1777.62...
必得科技跌2.05%,成交额1... 5月14日,必得科技盘中下跌2.05%,截至10:56,报12.90元/股,成交1339.76万元,...
立方制药涨2.02%,成交额9... 5月14日,立方制药盘中上涨2.02%,截至10:57,报23.77元/股,成交9439.78万元,...
兰州市城关区首次开展公共服务政... 城关区首次开展公共服务政策健康影响评估  5月13日,兰州市城关区召开公共服务政策健康影响评估会议暨...
哪吒汽车关联公司超10亿人民币...   5月14日上午消息,天眼风险信息显示,哪吒汽车关联公司合众新能源汽车股份有限公司有10亿人民币、...
瀚川智能跌2.05%,成交额1... 5月14日,瀚川智能盘中下跌2.05%,截至10:51,报13.88元/股,成交1667.10万元,...
2024年上海宝山绿色低碳产业... 5月14日,界面新闻从上海宝山获悉,2024年宝山区绿色低碳产业规模已达1003.69亿元,首次突破...
美股三大指数涨跌不一 标普50... 来源:环球网 【环球网财经综合报道】当地时间周二,美股市场呈现分化走势,三大指数收盘涨跌互现。其中,...
瑞凌股份跌2.05%,成交额2... 5月14日,瑞凌股份盘中下跌2.05%,截至10:58,报10.03元/股,成交2729.60万元,...
研究称中国痴呆人数激增 【#研究称中国痴呆人数激增#】最近,上海复旦大学的一项研究显示,过去30年间,中国痴呆患者数量从19...
青少年阅读,筑就生命基石——来... 青少年红色阅读接力活动。 主办方供图当人工智能(AI)的浪潮扑面而来,全民阅读迎来变革之年,如何让阅...
技能之星丨赵慧仪:破茧成蝶的舞... 转自:邯郸网络广播电视台2025年河北省职业院校技能大赛舞蹈表演(中职组)现场,邯郸科实中等专业学校...
【研报推荐】华润微:25Q1盈... 转自:新华财经华润微季报点评_25Q1盈利同比高增,汽车和AI应用持续带来需求增量.pdf
费高云卸任安徽副省长,此前已任... 转自:长安街知事据安徽日报消息,5月14日上午,安徽省十四届人大常委会第十六次会议通过人事任免案,决...
电子烟概念股集体上扬 华宝国际... .ct_hqimg {margin: 10px 0;} .hqimg_wrapper {text-a...
中自科技跌2.03%,成交额4... 5月14日,中自科技盘中下跌2.03%,截至10:51,报22.64元/股,成交4916.13万元,...