欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入解析ECMAScript?2023?中的新數(shù)組方法

 更新時(shí)間:2023年12月19日 09:10:13   作者:CodeForBetter  
ECMAScript?是一種標(biāo)準(zhǔn)化的腳本語(yǔ)言,它是?JavaScript?的規(guī)范。ECMAScript?2023?是?JavaScript?編程語(yǔ)言的更新,旨在帶來(lái)改進(jìn)并使?JavaScript?程序可預(yù)測(cè)和可維護(hù),這篇文章主要介紹了探索?ECMAScript?2023?中的新數(shù)組方法,需要的朋友可以參考下

前言

ECMAScript 2023 引入了一些新功能,以改進(jìn)語(yǔ)言并使其更加強(qiáng)大和無(wú)縫。這個(gè)新版本帶來(lái)了令人興奮的功能和新的 JavaScript 數(shù)組方法,使使用 JavaScript 編程更加愉快和輕松。本文將帶領(lǐng)讀者全面了解數(shù)組原型上新 JavaScript 方法。

什么是ECMAScript?

ECMAScript 是一種標(biāo)準(zhǔn)化的腳本語(yǔ)言,它是 JavaScript 的規(guī)范。ECMAScript 2023 是 JavaScript 編程語(yǔ)言的更新,旨在帶來(lái)改進(jìn)并使 JavaScript 程序可預(yù)測(cè)和可維護(hù)。

ECMAScript 2023 引入的新方法

toReversed()

toReversed() 與 reverse() 類似。 toReversed() 方法以相反的順序返回?cái)?shù)組的元素,而不更改原始數(shù)組。(請(qǐng)注意,ECMAScript 2023 代碼片段中的新 JavaScript 方法在現(xiàn)代 Web瀏覽器上運(yùn)行。從 MDN 檢查瀏覽器功能。它適用于瀏覽器,因?yàn)榉椒ㄈ匀缓苄?。此外,Node.js 不支持這些方法。Node.js 版本 20+ 支持它們。這不利于開發(fā)人員,因?yàn)殚_發(fā)人員使用 Node.js LTS 版本(版本 18)。)

eg:讓我們看一下按時(shí)間順序排列的一周中幾天的列表。結(jié)果將以相反的順序顯示。

//This is the original array
const days = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday'];
//Using reverse()
const reverseDays=days.reverse();
console.log(reverseDays);
//Output: ['Friday', 'Thursday', 'Wednesday', 'Tuesday', 'Monday']
console.log(days);
//Output of original array is changed: ['Friday', 'Thursday', 'Wednesday', 'Tuesday', 'Monday'
 

使用該 reverse() 方法修改原始數(shù)組。

eg: toReversed() 方法在不更改原始數(shù)組的情況下反轉(zhuǎn)數(shù)組??纯催@個(gè)例子:

 
//Using toReversed() method
const reversedDays=days.toReversed();
console.log(reversedDays);
//Output: ['Friday', 'Thursday', 'Wednesday', 'Tuesday', 'Monday']
console.log(days);
//Output of original array is not changed: ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']

toReversed() 功能是開發(fā)人員欣賞的一項(xiàng)顯著功能。這是因?yàn)樵紨?shù)組是用該 reverse() 方法變異的。感謝 ECMAScript 2023 引入該 toReversed() 方法。使用此方法,您可以更改數(shù)組的副本,而不是原始數(shù)組。

toSorted()

toSorted() 類似于 JavaScript 的 sort() 方法。但兩種方法彼此不同,是的!你猜對(duì)了。與 sort() 不同,toSorted() 方法不會(huì)更改原始數(shù)組。 toReversed() 方法返回一個(gè)新數(shù)組,使原始數(shù)組保持不變。

eg: 考慮這種情況,我們需要按升序?qū)?shù)字進(jìn)行排序。此示例將說(shuō)明 和 toSorted() 之間的區(qū)別。

//This is the original array
const numbers=[9, 4, 8, 1, 6, 3];
//Using sort
const sortNumbers=numbers.sort();
console.log(sortNumbers);
// Output:[1, 3, 4, 6, 8, 9]
console.log(numbers)//original array
//Output:[1, 3, 4, 6, 8, 9]
//Using toSorted
const sortNumbers=numbers.toSorted();
console.log(sortNumbers);
// Output:[1, 3, 4, 6, 8, 9]
console.log(numbers)//original array
//Output:[9, 4, 8, 1, 6, 3]
//Original array is not mutated

toSorted() 方法修改上述實(shí)例中的復(fù)制版本。它返回一個(gè)新數(shù)組,其中元素按升序排序。但是,原始數(shù)組不會(huì)更改。另一方面, sort() 方法將原始數(shù)組就地改變,如上面的示例所示。

toSpliced()

toSpliced() 數(shù)組方法是 ECMAScript 2023 中的一項(xiàng)新功能。類似于 JavaScript 的 splice() 數(shù)組方法,但略有不同。兩種數(shù)組方法的區(qū)別在于 toSpliced() 不會(huì)修改原來(lái)的數(shù)組。toSpliced() 創(chuàng)建一個(gè)包含已更改元素的新數(shù)組,但原始數(shù)組保持不變。 toSpliced() 可以在一個(gè)數(shù)組中執(zhí)行多項(xiàng)操作。您可以添加、刪除和替換數(shù)組中的元素。

eg: 讓我們考慮一個(gè)場(chǎng)景,我們有一個(gè)元素列表,并希望在不更改原始數(shù)組的情況下刪除一些元素。此示例將說(shuō)明 和 toSpliced 之間的區(qū)別 splice() 。

//Original array
const fruits=['Grapes', 'Oranges', 'Bananas', 'Mangoes', 'Pineapples'];
//Using Splice
const spliceFruits= fruits.splice(2,1);//removing one fruit(Bananas)
console.log(spliceFruits);
//Output: ['Grapes', 'Oranges', 'Mangoes', 'Pineapples']
console.log(fruits);//original array is altered
//Output: ['Grapes', 'Oranges', 'Mangoes', 'Pineapples']
//Using toSpliced
const splicedFruits= fruits.toSpliced(4,1);//removing one fruit(Pineapples)
console.log(splicedFruits);
//Output: ['Grapes', 'Oranges', 'Bananas', 'Mangoes']
console.log(fruits);//original array remain unmodified
//Output: ['Grapes', 'Oranges', 'Bananas', 'Mangoes', 'Pineapples']
// Adding an element at index 1
const fruits2 = fruits.toSpliced(1, 0, "Passion");
console.log(fruits2); 
//Output: ['Grapes', 'Passion', 'Oranges', 'Bananas', 'Mangoes', 'Pineapples']
// Replacing one element at index 1 with two new elements
const fruits3 = fruits2.toSpliced(1, 1, "Guava", "Melon");
console.log(fruits3); 
//Output: ['Grapes', 'Guava', 'Melon', 'Oranges', 'Bananas', 'Mangoes', 'Pineapples']
//Original array remain unchanged
console.log(fruits)
//Output: ['Grapes', 'Oranges', 'Bananas', 'Mangoes', 'Pineapples']

toSpliced() 數(shù)組方法是 JavaScript 語(yǔ)言的一個(gè)重要附加功能。它允許開發(fā)人員在不更改原始數(shù)組的情況下操作數(shù)組。這使開發(fā)人員能夠輕松管理和維護(hù)代碼。如上面的示例所示,此方法提供了一種更方便的方法來(lái)添加、刪除或替換任何數(shù)組索引處的元素。

with()

with() 數(shù)組方法在引入 ECMAScript 2021 (ES12) 時(shí)被添加到 JavaScript 編程語(yǔ)言中。更新數(shù)組中的元素在 JavaScript 中很常見。但是,更改數(shù)組元素會(huì)修改初始數(shù)組。with()數(shù)組方法在 ECMAScript 2023 中引入了一項(xiàng)新功能。該 with() 方法提供了一種在不更改原始數(shù)組的情況下更新數(shù)組中元素的安全方法。

eg: 這是通過(guò)返回一個(gè)包含更新元素的新數(shù)組來(lái)實(shí)現(xiàn)的。

const flowers=['Lily', 'Daisy', 'Iris', 'Lotus', 'Allium'];
//old way of updating an array;
flowers [4]='Rose';
console.log(flowers);
//Output: ['Lily', 'Daisy', 'Iris', 'Lotus', 'Rose']
//New way of updating an array using with()
const updatedFlowers=flowers.with(4, 'Aster');
console.log(updatedFlowers);
//Output: ['Lily', 'Daisy', 'Iris', 'Lotus', 'Aster']
console.log(flowers);//original array
Output: ['Lily', 'Daisy', 'Iris', 'Lotus', 'Allium']

更新數(shù)組的舊方法使用括號(hào)表示法來(lái)更改數(shù)組中的元素。使用括號(hào)表示法更新數(shù)組,將修改原始數(shù)組。但是,該 with() 方法在更新特定數(shù)組索引中的元素后會(huì)獲得相同的結(jié)果,但不會(huì)改變?cè)紨?shù)組。您可以創(chuàng)建數(shù)組的副本,該副本將返回一個(gè)具有更新索引的新數(shù)組。

總結(jié)

ECMAScript 不斷進(jìn)步,因?yàn)樗磕甓紩?huì)推出新版本。這是自2015年以來(lái)一直存在的趨勢(shì)。這種轉(zhuǎn)變每年都在發(fā)生,以改進(jìn) ECMAScript 和 JavaScriptECMAScript 2023 為 JavaScript 語(yǔ)言帶來(lái)了幾個(gè)令人興奮的功能。這些功能改進(jìn)了語(yǔ)言功能和開發(fā)人員體驗(yàn)。

使用這些上述數(shù)組方法,開發(fā)人員可以接受數(shù)組數(shù)據(jù)的不可變性,因?yàn)樗麄兛梢源_保原始數(shù)組保持不變。它們將增強(qiáng)開發(fā)人員在使用數(shù)組時(shí)的工作。保持?jǐn)?shù)據(jù)不變是有利的,正如 ECMAScript 2023 中的這些數(shù)組方法所證明的那樣。這些好處適用于任何 JavaScript 對(duì)象,而不僅僅是數(shù)組。

到此這篇關(guān)于探索 ECMAScript 2023 中的新數(shù)組方法的文章就介紹到這了,更多相關(guān)ECMAScript 2023數(shù)組內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 小程序?qū)崿F(xiàn)自定義導(dǎo)航欄適配完美版

    小程序?qū)崿F(xiàn)自定義導(dǎo)航欄適配完美版

    這篇文章主要介紹了小程序?qū)崿F(xiàn)自定義導(dǎo)航欄適配完美版,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • layui輸入框只允許輸入中文且判斷長(zhǎng)度的例子

    layui輸入框只允許輸入中文且判斷長(zhǎng)度的例子

    今天小編就為大家分享一篇layui輸入框只允許輸入中文且判斷長(zhǎng)度的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • DWR3 訪問(wèn)WEB元素的兩種方法實(shí)例詳解

    DWR3 訪問(wèn)WEB元素的兩種方法實(shí)例詳解

    這篇文章主要介紹了DWR3 訪問(wèn)WEB元素的兩種方法實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • js的math中缺少的數(shù)學(xué)方法小結(jié)

    js的math中缺少的數(shù)學(xué)方法小結(jié)

    JavaScript?Math對(duì)象包含一些真正有用且強(qiáng)大的數(shù)學(xué)運(yùn)算,但它缺乏大多數(shù)其他語(yǔ)言提供的許多重要運(yùn)算,例如求和,乘積,奇數(shù)和偶數(shù)等等,本文就來(lái)介紹一下
    2023-08-08
  • JavaScript樹結(jié)構(gòu)深度優(yōu)先算法

    JavaScript樹結(jié)構(gòu)深度優(yōu)先算法

    這篇文章主要介紹了JavaScript樹結(jié)構(gòu)深度優(yōu)先算法,樹結(jié)構(gòu)可以說(shuō)是前端中最常見的數(shù)據(jù)結(jié)構(gòu)之一,比如說(shuō)DOM樹、級(jí)聯(lián)選擇、樹形組件,更多相關(guān)內(nèi)容需要的小伙伴可以參考一下
    2022-07-07
  • 基于JS正則表達(dá)式實(shí)現(xiàn)模板數(shù)據(jù)動(dòng)態(tài)渲染(實(shí)現(xiàn)思路詳解)

    基于JS正則表達(dá)式實(shí)現(xiàn)模板數(shù)據(jù)動(dòng)態(tài)渲染(實(shí)現(xiàn)思路詳解)

    這篇文章主要介紹了基于JS正則表達(dá)式實(shí)現(xiàn)模板數(shù)據(jù)動(dòng)態(tài)渲染 ,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • js中的document.querySelector()方法舉例詳解

    js中的document.querySelector()方法舉例詳解

    這篇文章主要給大家介紹了關(guān)于js中document.querySelector()方法的相關(guān)資料,document.querySelector是JavaScript中的一個(gè)內(nèi)置方法,用于通過(guò)CSS選擇器選擇文檔中的第一個(gè)匹配元素,需要的朋友可以參考下
    2024-01-01
  • bootstrap按鈕插件(Button)使用方法解析

    bootstrap按鈕插件(Button)使用方法解析

    這篇文章主要為大家詳細(xì)解析了bootstrap按鈕插件Button使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 深入理解JavaScript 參數(shù)按值傳遞

    深入理解JavaScript 參數(shù)按值傳遞

    本篇文章主要介紹了深入理解JavaScript 參數(shù)按值傳遞,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • 基于jQuery的模仿新浪微博時(shí)間的組件

    基于jQuery的模仿新浪微博時(shí)間的組件

    廢話不多說(shuō),實(shí)現(xiàn)原理主要是處理table,生成tr td,其中最重要的是如何找出每月第一天是星期幾,然后就能對(duì)應(yīng)出這個(gè)月的余下天數(shù).
    2011-10-10

最新評(píng)論