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

JavaScript 高級單行代碼詳解

開發(fā) 前端
今天我們一起來了解一下關(guān)于JavaScript 的高級單行代碼的詳細解析。

1. 通過鍵對對象數(shù)組進行分組

我們定義了一個名為 groupBy 的函數(shù),它以一個對象數(shù)組和一個鍵作為參數(shù)。該函數(shù)的目的是將數(shù)組中的對象按指定的鍵進行分組。

const groupBy = (arr, key) =>
arr.reduce(
(acc, obj) => ({ ...acc, [obj[key]]: [...(acc[obj[key]] || []), obj] }),
{}
)


const people = [
{ name: "Alice", age: 21 },
{ name: "Bob", age: 22 },
{ name: "Charlie", age: 21 },
{ name: "David", age: 23 },
{ name: "Eve", age: 22 }
]


console.log(groupBy(people, "age"))


/* Output:
{
21: [
{ name: "Alice", age: 21 },
{ name: "Charlie", age: 21 }
],
22: [
{ name: "Bob", age: 22 },
{ name: "Eve", age: 22 }
],
23: [{ name: "David", age: 23 }]
}
*/

acc 參數(shù)是累加分組對象的累加器。obj 參數(shù)表示數(shù)組中的每個對象。

在 reduce() 方法內(nèi)部,使用擴展運算符 (...acc) 返回一個新對象。這將創(chuàng)建 accumulator 對象的淺表副本,以便可以在不更改原始對象的情況下對其進行修改。

新對象的屬性設置為與 key 參數(shù)的值相匹配的鍵。該屬性的值是一個包含被迭代對象的數(shù)組。

(acc[obj[key]] || []) 表達式檢查該屬性是否存在于累加器對象中。如果不存在,則返回一個空數(shù)組。展開運算符用于將數(shù)組與正在迭代的當前對象連接起來。

最后,groupBy() 函數(shù)返回包含分組對象的累加器對象。

2. 返回數(shù)組的中位數(shù)

我們實現(xiàn)了一個名為 median 的函數(shù),它將一個數(shù)字數(shù)組作為輸入,按升序?qū)ζ溥M行排序,并返回排序后的數(shù)組的中值。

當數(shù)組的元素個數(shù)為奇數(shù)時,排序數(shù)組的中值就是中間的元素。當數(shù)組元素個數(shù)為偶數(shù)時,中值取中間兩個元素的平均值。

const median = (arr) => {
const sorted = arr.sort()
const middle = Math.floor(sorted.length / 2)
return sorted.length % 2 === 0
? (sorted[middle - 1] + sorted[middle]) / 2
: sorted[middle]
}


const oddArr = [3, 1, 4, 2, 5]
console.log(median(oddArr)) // 3


const evenArr = [1, 2, 5, 6]
console.log(median(evenArr)) // 3.5

第一個例子,輸入數(shù)組[3, 1, 4, 2, 5]被排序為[1, 2, 3, 4, 5],中間元素為3。因此,輸入數(shù)組的中值 是 3。

在第二個例子中,輸入數(shù)組[1,2,5,6]被排序為[1,2,5,6],中間兩個元素為2和5。因此,輸入數(shù)組的中值為 (2 + 5) / 2 = 3.5。

3.返回數(shù)組的模式

數(shù)組的眾數(shù)是數(shù)組中出現(xiàn)頻率最高的值。如果有多個值具有相同的最高頻率,則所有這些值都被視為眾數(shù)。

const mode = (arr) => {
const counts = arr.reduce(
(acc, curr) => ({ ...acc, [curr]: (acc[curr] || 0) + 1 }),
{}
)


const maxCount = Math.max(...Object.values(counts))


return Object.keys(counts)
.filter((key) => counts[key] === maxCount)
.map(Number)
}


const arr1 = [1, 2, 3, 2, 4, 2, 5]
console.log(mode(arr1)) // [2]


const arr2 = [1, 2, 3, 2, 4, 4, 5]
console.log(mode(arr2)) // [2, 4]

在第一個示例中,輸入數(shù)組 [1, 2, 3, 2, 4, 2, 5] 的計數(shù)為 { 1: 1, 2: 3, 3: 1, 4: 1, 5: 1 }。最高計數(shù)為 3,出現(xiàn)值 2。因此,輸入數(shù)組的模式為 [2]。

在第二個示例中,輸入數(shù)組 [1, 2, 3, 2, 4, 4, 5] 的計數(shù)為 { 1: 1, 2: 2, 3: 1, 4: 2, 5: 1 }。最高計數(shù)為 2,出現(xiàn)在值 2 和 4 中。因此,輸入數(shù)組的模式為 [2, 4]。

4. 使用擴展運算符和 Array.from 創(chuàng)建一個長度為 n 的數(shù)組

使用擴展運算符和 Array.from() 創(chuàng)建一個長度為 n 的新數(shù)組。生成的數(shù)組包含從 0 到 n-1 的升序排列的數(shù)字。

const n = 5
const arr = [...Array.from({ length: n }, (_, index) => index)]


console.log(arr) // [ 0, 1, 2, 3, 4 ]

在此示例中,n 設置為 5,因此,生成的數(shù)組 arr 的長度為 5。數(shù)組的值是使用函數(shù) (_, index) => index 生成的,該函數(shù)返回數(shù)組的當前索引。因此,結(jié)果數(shù)組將為 [0, 1, 2, 3, 4]。

5. 使用解構(gòu)獲取數(shù)組的最后一個元素

此函數(shù)的目的是使用解構(gòu)獲取數(shù)組的最后一個元素。

const last = (arr) => [...arr].pop()


const people = [
{ name: "Alice", age: 21 },
{ name: "Bob", age: 22 },
{ name: "Charlie", age: 21 },
{ name: "David", age: 23 },
{ name: "Eve", age: 22 }
]


console.log(last(people)) // { name: "Eve", age: 22 }

在 last() 函數(shù)內(nèi)部,展開運算符 (...) 用于創(chuàng)建原始數(shù)組的副本。這是必需的,因為 pop() 方法會修改原始數(shù)組并返回刪除的元素。

然后,對數(shù)組的副本調(diào)用 pop() 方法,刪除并返回數(shù)組的最后一個元素。由于在調(diào)用 pop() 方法之前復制了數(shù)組,因此不會修改原始數(shù)組。

last() 函數(shù)返回數(shù)組的最后一個元素。

6. 使用布爾構(gòu)造函數(shù)檢查變量是否為真

我們函數(shù)的目的是使用布爾構(gòu)造函數(shù)檢查變量是否為真。

布爾構(gòu)造函數(shù)是 JavaScript 中的一個內(nèi)置函數(shù),可將值轉(zhuǎn)換為布爾值。如果該值為 truthy,則布爾構(gòu)造函數(shù)返回 true。如果該值為 falsy,則布爾構(gòu)造函數(shù)返回 false。

const isTruthy = (val) => Boolean(val)


console.log(isTruthy(false)) // false
console.log(isTruthy(0)) // false
console.log(isTruthy(-0)) // false
console.log(isTruthy(0n)) // false
console.log(isTruthy("")) // false
console.log(isTruthy(null)) // false
console.log(isTruthy(undefined)) // false
console.log(isTruthy(NaN)) // false


console.log(isTruthy(true)) // true
console.log(isTruthy({})) // true
console.log(isTruthy([])) // true
console.log(isTruthy(42)) // true
console.log(isTruthy("0")) // true
console.log(isTruthy("false")) // true
console.log(isTruthy(new Date())) // true
console.log(isTruthy(Infinity)) // true

7. 從數(shù)組中刪除虛假值

布爾構(gòu)造函數(shù)用作 filter() 方法的回調(diào)函數(shù)。如果值為真,則布爾構(gòu)造函數(shù)返回真,如果值為假,則返回假。因此,filter() 方法從原始數(shù)組中刪除所有虛假值。

const compact = (arr) => arr.filter(Boolean)


const falsyArr = [false, 0, -0, 0n, "", null, undefined, NaN]
const mixArr = [true, false, {}, 0, [], "", "0", null, "false", undefined, 42]


console.log(compact(falsyArr)) // []
console.log(compact(mixArr)) // [ true, {}, [], '0', 'false', 42 ]

在 compact() 函數(shù)內(nèi)部,使用布爾構(gòu)造函數(shù)作為回調(diào)函數(shù)對 arr 參數(shù)調(diào)用 filter() 方法。這將返回一個新數(shù)組,其中僅包含原始數(shù)組的真值。

compact() 函數(shù)返回新數(shù)組。

當執(zhí)行 console.log() 語句時,compact(falsyArr) 的輸出是一個空數(shù)組,因為 falsyArr 數(shù)組中的所有值都是假的。compact(mixArr) 的輸出是一個數(shù)組,它只包含 mixArr 數(shù)組的真實值,即 true、一個空對象 {}、一個空數(shù)組 []、字符串“0”、字符串“false”,以及 數(shù)字 42。所有虛假值(false、0、""、null、undefined 和 NaN)都已從 mixArr 數(shù)組中刪除。

8. 將字符串數(shù)組轉(zhuǎn)換為數(shù)字

函數(shù)的目的是將字符串數(shù)組轉(zhuǎn)換為數(shù)字數(shù)組。Number 構(gòu)造函數(shù)用作 map() 方法的回調(diào)函數(shù)。Number 構(gòu)造函數(shù)將字符串轉(zhuǎn)換為數(shù)字。

const toNumbers = (arr) => arr.map(Number)


const strArr = ["1", "2", "3", "4", "5"]


console.log(toNumbers(strArr)) // [ 1, 2, 3, 4, 5 ]

在 toNumbers() 函數(shù)內(nèi)部,使用 Number 構(gòu)造函數(shù)作為回調(diào)函數(shù)對 arr 參數(shù)調(diào)用 map() 方法。這將返回一個包含轉(zhuǎn)換值的新數(shù)組。

9. 返回一個鍵值翻轉(zhuǎn)的對象

此函數(shù)的目的是返回一個新對象,其中翻轉(zhuǎn)了原始對象的鍵和值。

Object.entries() 方法用于從原始對象創(chuàng)建鍵值對數(shù)組。然后使用 map() 方法迭代數(shù)組中的每個鍵值對,并返回一個新的翻轉(zhuǎn)鍵值對數(shù)組。最后,使用 Object.fromEntries() 方法從翻轉(zhuǎn)的鍵值對數(shù)組中創(chuàng)建一個新對象。

const flip = (obj) =>
Object.fromEntries(Object.entries(obj).map(([key, value]) => [value, key]))


const myDog = {
firstName: "oscar",
lastName: "king",
age: 3
}


console.log(flip(myDog)) // { 3: 'age', oscar: 'firstName', king: 'lastName' }

在 flip() 函數(shù)內(nèi)部,對 obj 參數(shù)調(diào)用 Object.entries() 方法以創(chuàng)建鍵值對數(shù)組。然后,在鍵值對數(shù)組上調(diào)用 map() 方法。對于每個鍵值對,map() 方法解構(gòu)鍵和值變量,并返回一個新數(shù)組,其中值作為第一個元素,鍵作為第二個元素。這將創(chuàng)建一個翻轉(zhuǎn)的鍵值對數(shù)組。

最后,在翻轉(zhuǎn)的鍵值對數(shù)組上調(diào)用 Object.fromEntries() 方法以使用翻轉(zhuǎn)的鍵值對創(chuàng)建一個新對象。

flip() 函數(shù)返回新對象。

執(zhí)行 console.log() 語句時,輸出是一個新對象,其中翻轉(zhuǎn)了原始 myDog 對象的鍵和值。firstName 鍵及其值“oscar”已翻轉(zhuǎn)為“oscar”鍵及其值“firstName”。lastName 鍵及其值“king”已翻轉(zhuǎn)為“king”鍵及其值“l(fā)astName”。age 鍵及其值 3 已翻轉(zhuǎn)為 3 鍵及其值“age”。

10. 返回一個只有特定鍵的對象

此函數(shù)的目的是返回一個新對象,該對象僅包含原始對象中指定的鍵及其對應的值。

const pick = (obj, keys) =>
Object.fromEntries(
Object.entries(obj).filter(([key]) => keys.includes(key))
)


const myDog = {
firstName: "oscar",
lastName: "king",
age: 3
}


console.log(pick(myDog, [])) // {}
console.log(pick(myDog, ["firstName"])) // { firstName: 'oscar' }
console.log(pick(myDog, ["firstName", "lastName"])) // { firstName: 'oscar', lastName: 'king' }

在 pick() 函數(shù)內(nèi)部,對 obj 參數(shù)調(diào)用 Object.entries() 方法以創(chuàng)建鍵值對數(shù)組。然后,在鍵值對數(shù)組上調(diào)用 filter() 方法。對于每個鍵值對,filter() 方法解構(gòu)鍵變量,如果鍵數(shù)組包含鍵則返回 true。這將創(chuàng)建一個過濾后的鍵值對數(shù)組。

最后,在過濾后的鍵值對數(shù)組上調(diào)用 Object.fromEntries() 方法來創(chuàng)建一個僅包含指定鍵及其對應值的新對象。pick() 函數(shù)返回新對象。

11. 返回一個只有唯一值的對象

此函數(shù) uniqueValues 將一個對象作為參數(shù)并返回一個新對象,該對象僅包含來自輸入對象的唯一值。

const uniqueValues = (obj) =>
Object.fromEntries(
Object.entries(obj).filter(
([key, value], index, entries) =>
entries.findIndex(([k, v]) => v === value) === index
)
)


const myDog = {
id: 3,
firstName: "oscar",
lastName: "oscar",
age: 3
}


console.log(uniqueValues(myDog)) // { id: 3, firstName: 'oscar' }

它首先在輸入對象上調(diào)用 Object.entries() 方法以獲取鍵值對數(shù)組。然后,它使用 filter() 方法過濾條目數(shù)組,并僅返回值唯一的條目。

要檢查一個值是否唯一,它在原始條目數(shù)組上使用 findIndex() 方法。它查找與當前過濾的條目具有相同值的第一個條目的索引。如果當前條目的索引等于第一個匹配條目的索引,則意味著該值是唯一的,應該包含在結(jié)果對象中。

最后,它使用 Object.fromEntries() 方法將過濾后的條目數(shù)組轉(zhuǎn)換回對象。

在示例代碼中,使用具有某些重復值的對象 myDog 調(diào)用 uniqueValues 函數(shù)。該函數(shù)返回一個僅包含唯一值并刪除重復值的新對象。生成的對象具有 id:3 和 firstName:'oscar'。

責任編輯:華軒 來源: web前端開發(fā)
相關(guān)推薦

2022-11-28 23:44:26

JavaScript技巧程序員

2023-02-15 16:19:59

JavaScript技巧API

2022-10-20 15:16:23

JavaScript數(shù)組技能

2023-10-10 16:20:38

JavaScript代碼技巧

2024-10-09 14:45:41

2022-12-19 15:23:51

JavaScrip開發(fā)語言

2023-05-30 15:11:16

JavaScrip開發(fā)功能

2023-08-27 16:19:09

JavaScript編程語言

2023-06-14 15:51:48

JavaScript

2022-09-02 23:08:04

JavaScript技巧開發(fā)

2025-04-07 07:30:00

JavaScript前端

2025-02-25 11:12:53

2022-10-09 18:52:11

JavaScript開發(fā)數(shù)組

2024-09-04 14:00:16

2022-10-08 07:54:24

JavaScriptAPI代碼

2024-07-26 00:00:05

JavaScript單行技巧

2022-12-28 17:20:03

JavaScript解決方案

2024-11-14 08:35:50

JavaScript管道操作符

2021-04-21 07:53:12

JavaScript單行程序

2021-04-19 11:30:06

Java開發(fā)程序
點贊
收藏

51CTO技術(shù)棧公眾號

午夜天堂精品久久久久| 性网站在线播放| 久久中文字幕导航| 在线观看中文字幕不卡| 国产男女无遮挡| 99精品福利视频| 久久久久国产精品一区| 免费av在线网站| 你懂的视频一区二区| 国产亚洲视频在线| 精品麻豆一区二区三区| 在线日韩av片| 国产精品麻豆一区二区三区| 亚洲va欧美va国产va天堂影院| 尤物av无码色av无码| 国产精品一区免费在线观看| 欧日韩一区二区三区| 午夜免费一区| 成人在线看片| 激情综合中文娱乐网| 日韩精品一区二区三区外面| 国产精品免费看| 亚洲专区国产精品| 偷偷要 色偷偷| 日韩中文在线电影| 欧美午夜电影网| 国产爆乳无码一区二区麻豆| 欧美久久精品一级c片| 国产精品看片你懂得| 欧美日韩福利电影| 在线播放 亚洲| 国产中文精品久高清在线不| 欧美色图在线视频| 91在线播放视频| 欧美视频日韩| 欧美三级三级三级爽爽爽| 影音先锋另类| 国产精品自拍在线| 欧美韩日一区二区| 91精品国产一区二区| 亚洲男人天堂av网| 97碰在线视频| 一个色综合网| 亚洲欧美一区二区三区四区| av网站在线免费看推荐| 亚洲精品视频在线| 国产第一页视频| 国产精品久久久久影院老司| 黄色国产网站| 欧美欧美欧美欧美| 女海盗2成人h版中文字幕| 国产精品美女久久久久aⅴ国产馆| 在线观看成人免费视频| av在线加勒比| 国产成人午夜精品影院观看视频 | 欧美视频在线观看| 久久久久高清| 成人国产精品免费观看| 爆操妹子视频在线观看| 欧美人与禽zozo性伦| 亚洲精品一区av| 欧美天堂在线观看| 99999精品视频| 国产拍揄自揄精品视频麻豆| 成人天堂入口网站| 国产精品久久午夜夜伦鲁鲁| 国产超碰91| 日韩电影网1区2区| 国产免费一区二区| 一本一道综合狠狠老| 日本24小时在线高清视频| 国产精品免费人成网站| 日韩免费高清在线| 麻豆精品国产传媒mv男同| 精品高清视频| 久久97超碰色| 亚洲国产精品综合| aaa国产精品视频| 国产一区二区三区直播精品电影| 国产青青草在线| 亚洲色图美腿丝袜| 91精品国产91久久久久久黑人| www.射射射| 日韩欧美成人激情| 成人免费高清在线观看| 全色精品综合影院| 精品国产乱码久久久久久夜甘婷婷| 欧美黑人激情| 欧美日韩一区小说| 日韩精品视频在线观看一区二区三区| 无码av免费一区二区三区试看 | 国产精品字幕| 欧美日韩一区二区视频在线| 亚洲精品伦理在线| 日本亚洲欧洲无免费码在线| 国产高清精品一区二区三区| 91麻豆免费在线观看| 偷拍精品精品一区二区三区| 国内外成人免费视频| 中文字幕亚洲在| 全国精品免费看| 日本大臀精品| 在线不卡日本| 人人超碰91尤物精品国产| 中文字幕乱码在线播放| 91福利视频导航| 午夜视频久久久久久| 麻豆精品国产| 精品视频免费在线播放| 国产精品欧美精品| 欧美日韩破处| 中文字幕网av| 久久999免费视频| 2021中文字幕一区亚洲| 麻豆系列在线观看| 精品日韩电影| 亚洲高清免费视频| 日韩精品久久久久久久电影99爱| 97成人精品区在线播放| 亚洲天堂av在线播放| 免费人成精品欧美精品| 日韩在线影院| 少妇高清精品毛片在线视频| 91精品欧美久久久久久动漫 | 国产一区二区三区黄视频 | 99久久久国产| 黄网站色视频免费观看| 国产精品不卡一区二区三区| 欧美最新精品| 国产精品免费一区二区三区| 久久久亚洲午夜电影| 免费av片在线观看一道本| 岛国视频午夜一区免费在线观看| 欧美aaa级| 国产精品高潮呻吟久久av野狼| 日韩图片一区| 国产在线二区| 色哺乳xxxxhd奶水米仓惠香| 精品人在线二区三区| 久久久精品黄色| 在线观看日韩av电影| 日韩在线观看中文字幕| av网在线观看| 国产鲁鲁视频在线观看免费| 久久中国妇女中文字幕| 久久深夜福利免费观看| 精品久久久久久久久久久| 久久99精品久久久久久国产越南 | 天堂网av成人| 羞羞网站在线看| 亚色视频在线播放| 国产黄页在线观看| 国产精品久久久久久超碰 | 男人av在线| 男女羞羞电影免费观看| 无码播放一区二区三区| 亚洲精品视频一区二区三区| 久久99精品久久久久久秒播放器| 亚洲自拍偷拍色片视频| www.久久爱.cn| 日韩国产高清一区| 成人一区二区电影| 久久久久久欧美| 另类图片亚洲另类| 精品久久一区二区| 欧美日韩国产首页在线观看| 欧美日韩国产一区在线| 99久久国产免费看| 成人激情黄色小说| 蜜臀久久99精品久久久画质超高清| 99久久综合| av在线播放观看| aa在线视频| 麻豆视频在线观看免费网站| 激情六月丁香婷婷| 99re视频在线| 久久精品99久久久香蕉| 92看片淫黄大片看国产片| 久久亚洲精品一区二区| 国产视频一区不卡| 欧美成人a视频| 51精品视频一区二区三区| 欧美中文字幕亚洲一区二区va在线| 欧美在线免费| 一区二区三区中文在线| 99久久99久久综合| 亚洲最大黄网| 日本精品网站| 美女尤物在线视频| 超碰高清在线| 国产91精品对白在线播放| 日韩**一区毛片| 久久欧美中文字幕| 亚洲激情欧美激情| 亚洲va国产va欧美va观看| 欧美性大战久久| 亚洲国产成人在线| 奶水喷射视频一区| 91蝌蚪porny成人天涯| 亚洲免费观看高清在线观看|