国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

這些 JavaScript 新功能太酷了吧!

開發 前端
在 JavaScript正則表達式中有一個限制:命名捕獲組的名稱必須是唯一的。在某些情況下,開發者可能需要匹配具有多種格式的相同內容,例如日期,它們可能以YYYY-MM或MM-YYYY的形式出現。如果不允許重復使用組名,開發者就無法為這兩種格式使用相同的組名來提取年份。

每年,JavaScript 都會引入眾多新特性。本文就來看看,即將在 ECMAScript 2025 規范中出現的新功能!

注意:本文提到的這些新特性很多已經被主流瀏覽器支持!

圖片圖片

Promise.try

Promise.try 旨在解決JavaScript中處理可能返回Promise的函數時的一些不便之處,包括:

  • 統一處理同步和異步函數::在實際編程中,經常遇到需要處理一個函數f,這個函數可能是同步的,也可能是異步的(即返回Promise)。傳統上,為了統一處理這兩種情況,開發者可能不得不使用如Promise.resolve().then(f)這樣的模式,但這會導致即使f是同步函數,它也會在下一個事件循環中異步執行。
  • 異常處理::對于可能拋出異常的函數,開發者希望有一種簡潔的方式來捕獲并處理這些異常。Promise.try提供了一種類似于try-catch語句的語義,使得異常處理更加直觀和方便。
  • 代碼可讀性和簡潔性:傳統的Promise處理方式(如Promise.resolve().then(f)或new Promise(resolve => resolve(f())))相對冗長且不易記憶。Promise.try提供了一種更加簡潔和易于理解的語法,使得代碼更加清晰和易于維護。

新的Promise方法try就是為了解決上述問題。這個方法接受一個函數f作為參數,并立即執行該函數。如果f是同步函數并返回一個值,則Promise.try會返回一個解析為該值的Promise。如果f是異步函數并返回一個Promise,則Promise.try會返回該Promise并保持其狀態。如果f拋出異常,則Promise.try會返回一個拒絕的Promise,并帶有該異常作為拒絕原因。

舉個例子:

const f = () => {  
  console.log('Function f is executing');  
  return 42; // 假設這是一個同步函數,返回一個值  
};  
  
Promise.try(f).then(value => {  
  console.log('Received value:', value); // 輸出: Received value: 42  
});  
  
console.log('This will execute before the Promise.try callback');

在這個示例中,函數f是同步的,并返回一個值42。使用Promise.try包裝f后,可以在.then方法中接收到這個值,并且這個處理過程是異步的。但是,與Promise.resolve().then(f)不同的是,使用Promise.try時,如果f是同步函數,它會在當前事件循環中立即執行,而不是在下一個事件循環中。

另外,如果f是一個異步函數,比如返回一個Promise,那么Promise.try同樣可以處理這種情況:

const asyncF = () => {  
  return new Promise((resolve) => {  
    setTimeout(() => {  
      resolve('Async value');  
    }, 1000);  
  });  
};  
  
Promise.try(asyncF).then(value => {  
  console.log('Received async value:', value); // 一秒后輸出: Received async value: Async value  
});

在這個示例中,函數asyncF是異步的,并返回一個在1秒后解析的Promise。使用Promise.try包裝asyncF后,可以在.then方法中接收到這個異步值。

目前,Chrome、Edge、Firfox 的最新版本已支持該功能:

圖片圖片

全新 Set 方法

JavaScript 的內置Set類將新增一些方法,以便執行集合論中常見的操作,包括:

  • Set.prototype.intersection(other):返回兩個集合的交集。
  • Set.prototype.union(other):返回兩個集合的并集。
  • Set.prototype.difference(other):返回第一個集合與第二個集合的差集。
  • Set.prototype.symmetricDifference(other):返回兩個集合的對稱差。
  • Set.prototype.isSubsetOf(other):判斷第一個集合是否是第二個集合的子集。
  • Set.prototype.isSupersetOf(other):判斷第一個集合是否是第二個集合的超集。
  • Set.prototype.isDisjointFrom(other):判斷兩個集合是否不相交。

舉個例子:

// 創建兩個Set實例
const setA = new Set([1, 2, 3, 4]);
const setB = new Set([3, 4, 5, 6]);

// 交集: 返回兩個集合的公共元素
const intersection = setA.intersection(setB); // Set {3, 4}

// 并集: 返回兩個集合的所有元素,不重復
const union = setA.union(setB); // Set {1, 2, 3, 4, 5, 6}

// 差集: 返回第一個集合中有而第二個集合中沒有的元素
const difference = setA.difference(setB); // Set {1, 2}

// 對稱差: 返回在兩個集合中的元素,但不返回同時存在于兩個集合中的元素
const symmetricDifference = setA.symmetricDifference(setB); // Set {1, 2, 5, 6}

// 子集判斷: 判斷第一個集合是否是第二個集合的子集
const isSubset = setA.isSubsetOf(setB); // false

// 超集判斷: 判斷第一個集合是否是第二個集合的超集
const isSuperset = setA.isSupersetOf(setB); // false

// 不相交判斷: 判斷兩個集合是否不相交
const isDisjoint = setA.isDisjointFrom(setB); // false

目前,這些新方法已被主流瀏覽器普遍支持:

圖片圖片

全新正則表達式修飾符

正則表達式引擎將新增一些模式修飾符,包括:

  • i — 忽略大小寫(Ignore Case)
  • m — 多行模式(Multiline)
  • s — 單行模式(Single-line),也稱為“點全”模式
  • x — 擴展模式(Extended mode)

舉個例子:

// 這個正則表達式在匹配時忽略大小寫,但只在第一個字符上忽略
const re1 = /^[a-z](?-i:[a-z])$/i;
console.log(re1.test("ab")); // true
console.log(re1.test("Ab")); // true
console.log(re1.test("aB")); // false

// 這個正則表達式在匹配時忽略大小寫
const re2 = /^(?i:[a-z])[a-z]$/;
console.log(re2.test("ab")); // true
console.log(re2.test("Ab")); // true
console.log(re2.test("aB")); // false

導入屬性

在 JavaScript 模塊導入語句中將支持內聯語法,允許指定模塊屬性,以便支持不同類型的模塊。這些屬性通過with關鍵字后跟一個對象字面量來指定,對象中可以包含不同的鍵值對,例如{ type: "json" }。這樣可以提高安全性,防止服務器意外返回不同的MIME類型,導致代碼被意外執行。

舉個例子:

// 導入一個JSON模塊
import json from "./foo.json" with { type: "json" };

// 動態導入一個JSON模塊
import("foo.json", { with: { type: "json" } });

在這個例子中,import語句和import()函數都使用了with關鍵字來指定模塊的類型。這告訴JavaScript環境,foo.json是一個JSON模塊,而不是一個JavaScript模塊。

另外,還將對export語句進行擴展,允許在導出模塊時指定屬性。例如:

// 導出一個模塊,并指定其類型
export { val } from './foo.js' with { type: "javascript" };

JSON 模塊

目前,JavaScript模塊系統并不直接支持導入JSON文件,這導致開發者需要使用一些非標準的方法來導入JSON數據。在JavaScript 環境中,未來將以一種通用的方式導入JSON模塊。以標準化JSON模塊的導入過程,確保在所有符合ECMAScript規范的宿主環境中都能一致地處理JSON模塊。

解決方案是利用導入屬性來指示一個模塊是JSON格式的。這意味著開發者可以使用以下語法來導入JSON模塊:

import json from "./foo.json" with { type: "json" };
import("foo.json", { with: { type: "json" } });

在這個例子中,with { type: "json" }部分告訴JavaScript環境,foo.json是一個JSON模塊,應該被解析為JSON對象,并且該對象成為模塊的默認導出。

迭代

盡管迭代器是表示大型或可能是無限枚舉數據集的有用方式,但它們缺乏一些輔助方法,使得它們不如數組和其他有限數據結構那樣易于使用。這導致一些問題本可以通過迭代器更好地表示,但卻不得不用數組或使用庫來引入必要的輔助方法來解決。

迭代器原型上將引入一系列新方法,允許更通用的使用和消費迭代器,包括:

  • .map(mapperFn):允許對迭代器返回的每個元素應用一個函數。
  • .filter(filtererFn):允許跳過迭代器中未通過過濾器函數的值。
  • .take(limit):返回一個迭代器,最多產生底層迭代器產生的給定數量的元素。
  • .drop(limit):跳過底層迭代器產生的給定數量的元素,然后產生任何剩余的元素。
  • .flatMap(mapperFn):返回一個迭代器,它產生的是應用映射函數到底層迭代器產生的元素所生成的迭代器的所有元素。
  • .reduce(reducer [, initialValue ]):允許對迭代器返回的每個元素應用一個函數,同時跟蹤Reducer的最新結果(memo)。
  • .toArray():將非無限迭代器轉換為數組。
  • .forEach(fn):用于對迭代器執行副作用,接受一個函數作為參數。
  • .some(fn):檢查迭代器中的任何值是否與給定的謂詞匹配。
  • .every(fn):檢查迭代器生成的每個值是否通過了測試函數。
  • .find(fn):用于查找迭代器中第一個匹配的元素。

舉個例子:

function* naturals() {
  let i = 0;
  while (true) {
    yield i;
    i += 1;
  }
}

const result = naturals()
  .map(value => value * value)
  .take(3);

result.next(); // {value: 0, done: false}
result.next(); // {value: 1, done: false}
result.next(); // {value: 4, done: false}
result.next(); // {value: undefined, done: true}

正則表達式捕獲組命名支持重復

目前,在 JavaScript正則表達式中有一個限制:命名捕獲組的名稱必須是唯一的。在某些情況下,開發者可能需要匹配具有多種格式的相同內容,例如日期,它們可能以YYYY-MM或MM-YYYY的形式出現。如果不允許重復使用組名,開發者就無法為這兩種格式使用相同的組名來提取年份。

而未來將為不同的模式片段使用相同的組名,只要這些片段不是在同一選擇分支中。這樣,即使在復雜的正則表達式中,開發者也可以為相同類型的數據使用相同的組名,從而簡化了正則表達式的編寫和理解。

舉個例子:

// 假設想匹配兩種日期格式 YYYY-MM 或 MM-YYYY 并提取年份
let regex = /(?<year>[0-9]{4})-[0-9]{2}|[0-9]{2}-(?<year>[0-9]{4})/;

// 使用這個正則表達式匹配字符串
let str = "2023-10";
let match = str.match(regex);

// 無論日期格式如何,都能提取出年份
if (match) {
  console.log(match.groups.year); // 輸出: 2023
}

責任編輯:武曉燕 來源: 前端充電寶
相關推薦

2022-03-29 09:03:08

JavaScript數組語義

2019-10-24 13:12:22

開源技術 軟件

2024-03-11 14:34:04

JavaScript開發

2022-05-19 23:49:20

iOS蘋果功能

2021-02-23 12:30:21

VS CodeGithub代碼

2021-03-19 09:05:47

Chromebook谷歌電腦

2020-11-25 18:52:11

Windows 10微軟功能

2022-06-07 14:26:35

iOS蘋果功能

2021-05-11 05:39:07

Edge微軟瀏覽器

2009-06-19 12:53:56

Spring 2.0

2021-05-20 06:00:00

Windows 功能系統

2022-06-10 21:34:45

iOSiOS 16

2017-11-06 15:05:18

iPhone X功能iOS

2021-05-30 07:16:43

Edge 91 微軟瀏覽器

2013-11-13 10:07:26

Visual Stud微軟

2022-08-26 13:52:20

FedoraFedora 37

2022-10-20 09:41:49

XubuntuLinux軟件

2012-07-31 15:25:46

Word 2013Office 2013

2012-09-13 11:08:53

IBMdw

2012-07-20 10:21:13

Ubuntu開源
點贊
收藏

51CTO技術棧公眾號

婷婷成人激情| 秋霞a级毛片在线看| 久久99精品国产.久久久久久| 国产精品国产精品国产专区蜜臀ah| 亚洲a级精品| 91精品中文在线| 国产欧美日韩一级| 欧美xxxx吸乳| 国产精品理论片| 日韩av免费观影| 亚洲成人免费在线视频| 国产999精品在线观看| 国产欧美精品一区二区三区-老狼| 欧美亚洲不卡| 精品一区二区中文字幕| 欧美日韩一区二区精品| 欧美日韩国产观看视频| 色综合天天狠天天透天天伊人| 免费观看久久av| 婷婷久久伊人| 欧美人妖在线观看| 手机看片福利永久国产日韩| 亚洲国产高清不卡| 久久99亚洲网美利坚合众国| 欧美一区亚洲一区| 国产高清久久久| 青青久在线视频| 日韩av片电影专区| 高清在线观看日韩| 国产一级片在线| 国外视频精品毛片| 99久久久精品| 日本www在线| 成人欧美在线观看| 国产欧美日韩不卡| 末成年女av片一区二区下载| 国产精品久久一区二区三区| 亚洲免费视频中文字幕| 韩国主播福利视频一区二区三区| 91精品在线观看视频| 亚洲三级在线免费观看| 国产一区二区高清在线| www.国产二区| 日韩精品在线看| 欧美成年黄网站色视频| 国产美女搞久久| 色偷偷成人一区二区三区91| 97精品视频| 激情影院在线观看| 久久99热只有频精品91密拍| 91黄色免费版| 99精品国产一区二区青青牛奶 | 综合中文字幕亚洲| 色妞ww精品视频7777| 女性隐私黄www网站视频| 伊人伊成久久人综合网站| 国产精品2024| 一本久道综合色婷婷五月| 久久九九有精品国产23| 国产日韩欧美综合在线| 风间由美中文字幕在线看视频国产欧美 | 在线观看黄色小视频| 国产欧美日韩91| 欧美性高潮床叫视频| 欧美xxx在线观看| 国产美女福利在线| 黄色一级片黄色| 欧美精品videossex性护士| 国产亚洲精品bt天堂精选| 国产精品一区二区三区av麻 | 91亚洲精品久久久蜜桃| 老牛影视av一区二区在线观看| 国产超碰在线| 久久天天狠狠| 欧美精品亚州精品| 亚洲成精国产精品女| 日本不卡一区二区| 国产精东传媒成人av电影| 欧美女v视频| 免费成人深夜夜行网站视频| 国语自产在线不卡| 欧美视频日韩视频在线观看| 国产裸体歌舞团一区二区| 精品视频网站| 在线成人性视频| 国产精品视频久久| 亚洲午夜未删减在线观看| 五月天精品一区二区三区| 国产精品一卡二卡| 一区二区日韩免费看| av在线亚洲色图| 波多野结衣久久| 中文字幕在线网| 在线观看的毛片| 韩国黄色一级大片| 春色成人在线视频| 国产精品爽爽爽| 久久中文字幕在线视频| 欧美一区日韩一区| 天天亚洲美女在线视频| 国产日韩欧美高清| 成人蜜臀av电影| 日韩黄色免费电影| 伊人久久婷婷| 亚洲天堂av资源在线观看| 欧美一区二区三区四区在线观看地址 | 日本一区二区成人| 成人av在线影院| 麻豆国产一区二区| 日本不卡在线视频| 亚洲看片一区| 91精品亚洲| 欧美激情视频一区二区三区在线播放| 国产 日韩 欧美 综合 一区| 国产精品1区| 久久av国产紧身裤| 国产精品国产亚洲精品| 精品午夜av| 色天堂在线视频| 久久精品蜜桃| 国产福利在线| 五月婷婷在线视频| 成码无人av片在线观看网站| 岛国大片在线观看| 中国日本在线视频中文字幕| 香蕉av在线| 男人影院在线观看| 亚洲伊人av| 日韩高清一区| 97精品国产| 久久久久国产精品一区三寸| 麻豆精品在线看| 不卡视频免费播放| 亚洲综合视频在线| 欧美日韩久久不卡| 国产亚洲视频在线| 久久99国产综合精品女同| 日本精品视频在线观看| www.一区二区三区| 亚洲一二三区在线| 亚洲电影免费| 黄网视频在线观看| 成人三级网址| av自拍一区| 久久精品天堂| 国产精品美女久久久久久2018| 亚洲韩国精品一区| 亚洲性线免费观看视频成熟| 国产精品女主播| 国产精品无码电影在线观看| 国产原创精品在线| 国产婷婷视频在线| 欧美欧美黄在线二区| 精品一区二区在线播放| 一区二区三区四区亚洲| 中文字幕欧美日韩精品| 成人18视频| 色一情一乱一伦一区二区三区日本 | 中文av一区| 91在线精品一区二区| 欧美刺激脚交jootjob| 一本色道久久综合狠狠躁篇的优点| 国产精品视频精品视频| avav在线看| av福利在线导航| 欧美午夜一区二区福利视频| 国产精品理论在线观看| 国产一区二区三区在线看| 久久久精品国产一区二区三区| 国产女优裸体网站| 香港久久久电影| 成人网在线播放| 日韩精品免费在线播放| 欧美一区二区三区电影在线观看| 日本激情视频网| 国产精品网在线观看| 成人a免费在线看| 国产亚洲人成a一在线v站| 亚洲人成网站在线播放2019| 主播国产精品| 日本免费新一区视频| 777亚洲妇女| 日韩资源av在线| 日韩脚交footjobhd| 国产精品影视天天线| 国产亚洲精品久久久久动| 欧美牲交a欧美牲交aⅴ免费下载| 福利一区二区三区视频在线观看| 国产乱人伦偷精品视频不卡| 亚洲国产成人av在线| 欧美激情亚洲天堂| 久久香蕉一区| 国产日产精品一区二区三区四区的观看方式 | 中文字幕亚洲成人| 久久网这里都是精品| 国产精品久久久久久一区二区三区| 日本一区二区在线不卡| 日日摸夜夜添夜夜添精品视频| 国产 欧美在线| 亚洲一区二区av在线|