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的新功能,希望对你有所帮助,也希望你能从中学到新的知识。

相关内容

热门资讯

请问怎么乘坐地铁,方法,步骤? 请问怎么乘坐地铁,方法,步骤?首先我没见过,更没有坐过,所以我要问怎么坐地铁啊???其次广州不坐地铁...
两小时内告诉我答案!!! 我的... 两小时内告诉我答案!!! 我的喜欢 运动 看电影 读书 用韩语怎么翻译??저의 취미는 운동, 영화...
有没有主角实力强大却隐藏起来只... 有没有主角实力强大却隐藏起来只想平凡的过完生活的小说巜我真的长生不老》主角高中生,喜欢古典文化和同班...
郭德纲的长篇单口相声《今古奇观... 郭德纲的长篇单口相声《今古奇观》系列什么时候能完?听说是跟一个外地的出版社合作出版的,又没有消息灵通...
秋天的特点是什么? 秋天的特点是什么?秋季有三大特点:干燥、寒冷、果实成熟季。首先来说,干燥的天气,是秋天的必经过程,夏...
如何改写一个伤感的故事? 如何改写一个伤感的故事?一般故事的结局是最能体现伤感的。所以修改这个故事的结局。就能改掉这个伤感的故...
自然哲学是指什么 自然哲学是指什么自然哲学是指什么自然科学的前身 用哲学方法探求世界基本规律哲学的英文单词是philo...
考生报考教师招聘各年级段所需要... 考生报考教师招聘各年级段所需要的学历要求分别是什么?如果是报考幼师资格证需具有幼儿师范学校毕业或高等...
我表妹马上过20岁生日了,我想... 我表妹马上过20岁生日了,我想送首藏头诗或者藏尾诗给她,她的名字叫:沈明玉沈府佳人美无比,明月高照玉...
形容人讨厌成语 形容人讨厌成语 面目可憎miàn mù kě zēng[释义] 面目:面貌;可憎:令人厌恶。相貌...
为什么一听到声音就特别烦躁,有... 为什么一听到声音就特别烦躁,有时候还会控制不住想哭?是不是你最近压力太大了?去看看心理医生吧。要不然...
有没有知道名家描写四季的文章? 有没有知道名家描写四季的文章?只要是家描写四季的文章都行,大家帮找找吧~最好是夏天和冬天的~大家帮帮...
学习计划书的格式 学习计划书的格式急急急急急啊学习计划书格式分三块:1.学习计划书名称仔细回顾一下自己的学习情况,找出...
四年级下册暑假生活指导参考答案... 四年级下册暑假生活指导参考答案山东教育出版社(英语)是2011年的 是帮助tony闯关的。急急...
《翼年代记之东京默示录》主要讲... 《翼年代记之东京默示录》主要讲什么的讲的就是故事讲小樱及小狼来自玖楼国(在日文中,《魔卡少女樱》的大...
纪晓岚简介 纪晓岚简介 纪昀(jǐ yún),字晓岚,一字春帆,晚号石云,道号观弈道人。生于清雍正二年(17...
昨天买的奶茶今天有了一点沉淀物... 昨天买的奶茶今天有了一点沉淀物,还有一点酸味,还吃得了吗?如果你买的不是酸奶最好是不要吃了!这么热的...
冲熬是什么意思 冲熬是什么意思冲熬是什么意思封建迷信的意思
实木家具油漆工艺流程 实木家具油漆工艺流程实木家具刷油漆的方法步骤:第一步,卸把手等装饰品,为了防止把手等饰品沾上油漆,刷...
我想买一台收音机给我奶奶,请问... 我想买一台收音机给我奶奶,请问大家什么电台最适合老人听?最好是没有医学专家讲座的电台。谢谢各位了! ...