目錄
#這是JavaScript中最簡單的方法,但IE7和IE8不支援此方法。
#如果你用過.NET中的列舉,這兩個方法和 .Any(x => x.IsAwesome)
#.join
栈和队列的实现:.pop, .push, .shift.unshift
模型映射:.map
查询:.filter
排序:.sort(compareFunction)
计算:.reduce.reduceRight
复制:.slice
强大的.splice
查找:.indexOf
操作符:in
走近.reverse
首頁 web前端 js教程 JavaScript原生數組函數講解

JavaScript原生數組函數講解

Aug 09, 2017 pm 01:53 PM
javascript js 講解

在JavaScript中,建立陣列可以使用JavaScript原生數組函數講解建構函數,或是使用陣列直接量[],後者是首選方法。 JavaScript原生數組函數講解物件繼承自Object.prototype,對陣列執行typeof運算子傳回object而不是array。然而,[] instanceof JavaScript原生數組函數講解也回傳true。也就是說,類別數組物件的實作更複雜,例如strings物件、arguments對象,arguments物件不是JavaScript原生數組函數講解的實例,但有length屬性,並能透過索引取值,所以能像陣列一樣進行循環運算。 

在本文中,我將複習一些陣列原型的方法,並探討這些方法的用法。

  • 迴圈:.forEach

  • #判斷:.some.every

  • 區分.join.concat

  • 堆疊和佇列的實現:.pop, .push, .shift,和.unshift

  • ##模型映射:

    .map

  • #查詢:

    .filter

  • ##排序:
  • . sort

  • 計算:
  • .reduce

    .reduceRight

    ##複製:
  • .slice
  • 強大的
  • .splice
  • 找出:
  • .indexOf
  • 運算子:
  • in
  • #靠近
  • .reverse

#循環:JavaScript原生數組函數講解.forEach

#這是JavaScript中最簡單的方法,但IE7和IE8不支援此方法。

.forEach

有一個回呼函數作為參數,遍歷陣列時,每個陣列元素都會呼叫它,回呼函數接受三個參數:

    value
  • :目前元素

  • index
  • :目前元素的索引

  • array
  • :要遍歷的陣列

    此外,可以傳遞可選的第二個參數,作為每次函數呼叫的上下文(this).
    ##<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>[&amp;#39;_&amp;#39;, &amp;#39;t&amp;#39;, &amp;#39;a&amp;#39;, &amp;#39;n&amp;#39;, &amp;#39;i&amp;#39;, &amp;#39;f&amp;#39;, &amp;#39;]&amp;#39;].forEach(function (value, index, array) { this.push(String.fromCharCode(value.charCodeAt() + index + 2)) }, out = [])out.join(&amp;#39;&amp;#39;)// &lt;- &amp;#39;awesome&amp;#39;123456</pre><div class="contentsignin">登入後複製</div></div> 後文會提及

    .join
  • ,在這個範例中,它用來拼接陣列中的不同元素,效果類似
out[0] + '' + out[1] + '' + out[2] + '' + out[n]

不能中斷.forEach循環,並且拋出異常也是不明智的選擇。幸運的事我們有另外的方式來中斷操作。
判斷:.some

.every

#如果你用過.NET中的列舉,這兩個方法和 .Any(x => x.IsAwesome)

.All(x => x.IsAwesome)

類似。 .forEach的參數類似,需要一個包含value
index,和array三個參數的回呼函數,並且也有一個可選的第二個上下文參數。 MDN對.some的描述如下:some

將會給數組裡的每一個元素執行一遍回呼函數,直到回調函數傳回
true

。如果找到目標元素,some立即傳回true,否則some回傳false。回呼函數只對已經指定值的陣列索引執行;它不會對已刪除的或未指定值的元素呼叫。

max = -Infinity
satisfied = [10, 12, 10, 8, 5, 23].some(function (value, index, array) {    if (value > max) max = value    return value < 10})

console.log(max)// <- 12satisfied// <- true1234567891011
登入後複製
注意,當回呼函數的value < 10

時,中斷函數循環。
.every

的運作原理和.some類似,但回呼函數是傳回false而不是true。 區分.join

.concat

#.join

.concat

經常混淆。 .join(separator)separator作為分隔符號拼接數組元素,並傳回字串形式,如果沒有提供separator,將使用預設的 ,.concat會建立一個新數組,作為來源數組的淺拷貝。

.concat
    常用用法:
  • array.concat(val, val2, val3, valn)

    .concat
  • 傳回一個新陣列
  • #array.concat()
  • 在沒有參數的情況下,傳回來源陣列的淺拷貝。
  • 淺拷貝意味著新數組和原始數組保持相同的物件引用,這通常是好事。例如:

var a = { foo: &#39;bar&#39; }
var b = [1, 2, 3, a]
var c = b.concat()

console.log(b === c)// <- falseb[3] === a && c[3] === a// <- true123456789
登入後複製

栈和队列的实现:.pop, .push, .shift.unshift

每个人都知道.push可以再数组末尾添加元素,但是你知道可以使用[].push(&#39;a&#39;, &#39;b&#39;, &#39;c&#39;, &#39;d&#39;, &#39;z&#39;)一次性添加多个元素吗?
.pop 方法是.push 的反操作,它返回被删除的数组末尾元素。如果数组为空,将返回void 0 (undefined),使用.pop.push可以创建LIFO (last in first out)栈。

function Stack () {    this._stack = []
}

Stack.prototype.next = function () {    return this._stack.pop()
}

Stack.prototype.add = function () {    return this._stack.push.apply(this._stack, arguments)
}

stack = new Stack()
stack.add(1,2,3)

stack.next()// <- 31234567891011121314151617
登入後複製

相反,可以使用.shift.unshift创建FIFO (first in first out)队列。

function Queue () {
    this._queue = []
}

Queue.prototype.next = function () {    return this._queue.shift()
}

Queue.prototype.add = function () {    return this._queue.unshift.apply(this._queue, arguments)
}

queue = new Queue()
queue.add(1,2,3)

queue.next()// <- 1Using .shift (or .pop) is an easy way to loop through a set of array elements, while draining the array in the process.

list = [1,2,3,4,5,6,7,8,9,10]while (item = list.shift()) {
    console.log(item)
}

list// <- []123456789101112131415161718192021222324252627
登入後複製

模型映射:.map

.map为数组中的每个元素提供了一个回调方法,并返回有调用结果构成的新数组。回调函数只对已经指定值的数组索引执行;它不会对已删除的或未指定值的元素调用。

JavaScript原生數組函數講解.prototype.map 和上面提到的.forEach.some.every有相同的参数格式:.map(fn(value, index, array), thisArgument)

values = [void 0, null, false, &#39;&#39;]
values[7] = void 0result = values.map(function(value, index, array){    console.log(value)    return value
})// <- [undefined, null, false, &#39;&#39;, undefined × 3, undefined]12345678
登入後複製

undefined × 3很好地解释了.map不会对已删除的或未指定值的元素调用,但仍然会被包含在结果数组中。.map在创建或改变数组时非常有用,看下面的示例:

// casting[1, &#39;2&#39;, &#39;30&#39;, &#39;9&#39;].map(function (value) {    return parseInt(value, 10)
})// 1, 2, 30, 9[97, 119, 101, 115, 111, 109, 101].map(String.fromCharCode).join(&#39;&#39;)// <- &#39;awesome&#39;// a commonly used pattern is mapping to new objectsitems.map(function (item) {    return {
        id: item.id,
        name: computeName(item)
    }
})12345678910111213141516
登入後複製

查询:.filter

filter对每个数组元素执行一次回调函数,并返回一个由回调函数返回true的元素组成的新数组。回调函数只会对已经指定值的数组项调用。

通常用法:.filter(fn(value, index, array), thisArgument),跟C#中的LINQ表达式和SQL中的where语句类似,.filter只返回在回调函数中返回true值的元素。

[void 0, null, false, &#39;&#39;, 1].filter(function (value) {    return value
})// <- [1][void 0, null, false, &#39;&#39;, 1].filter(function (value) {    return !value
})// <- [void 0, null, false, &#39;&#39;]123456789
登入後複製

排序:.sort(compareFunction)

如果没有提供compareFunction,元素会被转换成字符串并按照字典排序。例如,”80”排在”9”之前,而不是在其后。

跟大多数排序函数类似,JavaScript原生數組函數講解.prototype.sort(fn(a,b))需要一个包含两个测试参数的回调函数,其返回值如下:

  • a在b之前则返回值小于0

  • a和b相等则返回值是0

  • a在b之后则返回值小于0

[9,80,3,10,5,6].sort()// <- [10, 3, 5, 6, 80, 9][9,80,3,10,5,6].sort(function (a, b) {    return a - b
})// <- [3, 5, 6, 9, 10, 80]1234567
登入後複製

计算:.reduce.reduceRight

这两个函数比较难理解,.reduce会从左往右遍历数组,而.reduceRight则从右往左遍历数组,二者典型用法:.reduce(callback(previousValue,currentValue, index, array), initialValue)
previousValue 是最后一次调用回调函数的返回值,initialValue则是其初始值,currentValue是当前元素值,index是当前元素索引,array是调用.reduce的数组。
一个典型的用例,使用.reduce的求和函数。

JavaScript原生數組函數講解.prototype.sum = function () {    return this.reduce(function (partial, value) {        return partial + value
    }, 0)
};

[3,4,5,6,10].sum()// <- 2812345678
登入後複製

如果想把数组拼接成一个字符串,可以用.join实现。然而,若数组值是对象,.join就不会按照我们的期望返回值了,除非对象有合理的valueOftoString方法,在这种情况下,可以用.reduce实现:

function concat (input) {    return input.reduce(function (partial, value) {        if (partial) {            partial += &#39;, &#39;
        }        return partial + value
    }, &#39;&#39;)
}

concat([
    { name: &#39;George&#39; },
    { name: &#39;Sam&#39; },
    { name: &#39;Pear&#39; }
])// <- &#39;George, Sam, Pear&#39;123456789101112131415
登入後複製

复制:.slice

.concat类似,调用没有参数的.slice()方法会返回源数组的一个浅拷贝。.slice有两个参数:一个是开始位置和一个结束位置。
JavaScript原生數組函數講解.prototype.slice 能被用来将类数组对象转换为真正的数组。

JavaScript原生數組函數講解.prototype.slice.call({ 0: &#39;a&#39;, 1: &#39;b&#39;, length: 2 })
// <- [&#39;a&#39;, &#39;b&#39;]12
登入後複製

这对.concat不适用,因为它会用数组包裹类数组对象。

JavaScript原生數組函數講解.prototype.concat.call({ 0: &#39;a&#39;, 1: &#39;b&#39;, length: 2 })
// <- [{ 0: &#39;a&#39;, 1: &#39;b&#39;, length: 2 }]12
登入後複製

此外,.slice的另一个通常用法是从一个参数列表中删除一些元素,这可以将类数组对象转换为真正的数组。

function format (text, bold) {    if (bold) {        text = &#39;<b>&#39; + text + &#39;</b>&#39;
    }
    var values = JavaScript原生數組函數講解.prototype.slice.call(arguments, 2)

    values.forEach(function (value) {        text = text.replace(&#39;%s&#39;, value)
    })    return text}format(&#39;some%sthing%s %s&#39;, true, &#39;some&#39;, &#39;other&#39;, &#39;things&#39;)// <- <b>somesomethingother things</b>123456789101112131415
登入後複製

强大的.splice

.splice 是我最喜欢的原生数组函数,只需要调用一次,就允许你删除元素、插入新的元素,并能同时进行删除、插入操作。需要注意的是,不同于`.concat.slice,这个函数会改变源数组。

var source = [1,2,3,8,8,8,8,8,9,10,11,12,13]
var spliced = source.splice(3, 4, 4, 5, 6, 7)

console.log(source)// <- [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12 ,13]spliced// <- [8, 8, 8, 8]12345678
登入後複製

正如你看到的,.splice会返回删除的元素。如果你想遍历已经删除的数组时,这会非常方便。

var source = [1,2,3,8,8,8,8,8,9,10,11,12,13]var spliced = source.splice(9)

spliced.forEach(function (value) {
    console.log(&#39;removed&#39;, value)
})// <- removed 10// <- removed 11// <- removed 12// <- removed 13console.log(source)// <- [1, 2, 3, 8, 8, 8, 8, 8, 9]12345678910111213
登入後複製

查找:.indexOf

利用.indexOf 可以在数组中查找一个元素的位置,没有匹配元素则返回-1。我经常使用.indexOf的情况是当我有比较时,例如:a === &#39;a&#39; || a === &#39;b&#39; || a === &#39;c&#39;,或者只有两个比较,此时,可以使用.indexOf[&#39;a&#39;, &#39;b&#39;, &#39;c&#39;].indexOf(a) !== -1
注意,如果提供的引用相同,.indexOf也能查找对象。第二个可选参数用于指定开始查找的位置。

var a = { foo: &#39;bar&#39; }
var b = [a, 2]

console.log(b.indexOf(1))// <- -1console.log(b.indexOf({ foo: &#39;bar&#39; }))// <- -1console.log(b.indexOf(a))// <- 0console.log(b.indexOf(a, 1))// <- -1b.indexOf(2, 1)// <- 11234567891011121314151617
登入後複製

如果你想从后向前搜索,可以使用.lastIndexOf

操作符:in

在面试中新手容易犯的错误是混淆.indexOfin操作符:

var a = [1, 2, 5]1 in a// <- true, but because of the 2!5 in a// <- false1234567
登入後複製

问题是in操作符是检索对象的键而非值。当然,这在性能上比.indexOf快得多。

var a = [3, 7, 6]1 in a === !!a[1]// <- true1234
登入後複製

走近.reverse

该方法将数组中的元素倒置。

var a = [1, 1, 7, 8]a.reverse()// [8, 7, 1, 1]1234
登入後複製

.reverse 会修改数组本身。

译文出处:http://www.ido321.com/1568.html

本文根据@Nicolas Bevacqua的《Fun with JavaScript Native JavaScript原生數組函數講解 Functions》所译,整个译文带有我自己的理解与思想,如果译得不好或有不对之处还请同行朋友指点。如需转载此译文,需注明英文出处:http://modernweb.com/2013/11/25/fun-with-javascript-native-array-functions/。

以上是JavaScript原生數組函數講解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用WebSocket和JavaScript實現線上語音辨識系統 如何使用WebSocket和JavaScript實現線上語音辨識系統 Dec 17, 2023 pm 02:54 PM

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

股票分析必備工具:學習PHP和JS繪製蠟燭圖的步驟 股票分析必備工具:學習PHP和JS繪製蠟燭圖的步驟 Dec 17, 2023 pm 06:55 PM

股票分析必備工具:學習PHP和JS繪製蠟燭圖的步驟,需要具體程式碼範例隨著網路和科技的快速發展,股票交易已成為許多投資者的重要途徑之一。而股票分析是投資人決策的重要一環,其中蠟燭圖被廣泛應用於技術分析。學習如何使用PHP和JS繪製蠟燭圖將為投資者提供更多直觀的信息,幫助他們更好地做出決策。蠟燭圖是一種以蠟燭形狀來展示股票價格的技術圖表。它展示了股票價格的

建議:優秀JS開源人臉偵測辨識項目 建議:優秀JS開源人臉偵測辨識項目 Apr 03, 2024 am 11:55 AM

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

WebSocket與JavaScript:實現即時監控系統的關鍵技術 WebSocket與JavaScript:實現即時監控系統的關鍵技術 Dec 17, 2023 pm 05:30 PM

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何使用WebSocket和JavaScript實現線上預約系統 如何使用WebSocket和JavaScript實現線上預約系統 Dec 17, 2023 am 09:39 AM

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

如何利用JavaScript和WebSocket實現即時線上點餐系統 如何利用JavaScript和WebSocket實現即時線上點餐系統 Dec 17, 2023 pm 12:09 PM

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

PHP與JS開發技巧:掌握繪製股票蠟燭圖的方法 PHP與JS開發技巧:掌握繪製股票蠟燭圖的方法 Dec 18, 2023 pm 03:39 PM

隨著網路金融的快速發展,股票投資已經成為了越來越多人的選擇。而在股票交易中,蠟燭圖是常用的技術分析方法,它能夠顯示股票價格的變動趨勢,幫助投資人做出更精準的決策。本文將透過介紹PHP和JS的開發技巧,帶領讀者了解如何繪製股票蠟燭圖,並提供具體的程式碼範例。一、了解股票蠟燭圖在介紹如何繪製股票蠟燭圖之前,我們首先需要先了解什麼是蠟燭圖。蠟燭圖是由日本人

JavaScript與WebSocket:打造高效率的即時天氣預報系統 JavaScript與WebSocket:打造高效率的即時天氣預報系統 Dec 17, 2023 pm 05:13 PM

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

See all articles