溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

微信小程序中ECMAScript5數(shù)組操作方法是什么

發(fā)布時間:2022-01-13 15:27:38 來源:億速云 閱讀:166 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要講解了“微信小程序中ECMAScript5數(shù)組操作方法是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“微信小程序中ECMAScript5數(shù)組操作方法是什么”吧!

首先補充說明一下,ECMAScript是歐洲計算機制造商協(xié)會(European Computer Manufacturers Association)為了統(tǒng)一各種script,以JavaScript1.1為基礎(chǔ)搞出來的一種腳本語言規(guī)范。ECMAScript5是這個規(guī)范第五個版本。由于它得到了各大瀏覽器廠商的響應(yīng)積極,所以稱得上是JavaScript的未來。微信小程序也支持ECMAScript5。

ECMASript5中的數(shù)組方法

forEach

forEach方法提供了一種相對簡單的(至少是在形式上)方法遍歷數(shù)組,它有3個參數(shù):數(shù)組元素,元素的索引和數(shù)組本身。

data = [1, 2, 3, 4, 5];

//所有元素求和

var sum = 0;

data.forEach(funtion(value){sum += value;}) 

sum                                                   //=>15

//每個元素乘2

data.forEach(function(v, i, a){ a[i] = v * 2;});

data               //=>[2, 4, 6, 8, 10]

看懂沒有?如果沒懂也不要緊,我們以乘2為例,稍微展開說明。代碼可能不能執(zhí)行,只是為了說明。

forEach的實現(xiàn)大致如下,想象的,偏差應(yīng)該不大。

function forEach(f)

{

    for(int i = 0;  i < array.length; i++)

        f(array[i], i, array);   

}

用戶定義一個函數(shù),參數(shù)為數(shù)組元素,元素的索引和數(shù)組本身。之所以這樣定義是forEach方法實現(xiàn)的要求。

function mul2(v, i, a)

{

    a[i] = v * 2;

}

接下來是調(diào)用

data.forEach(mul2);

這樣就好理解多了。示例中只是將定義乘2函數(shù)和調(diào)用該函數(shù)合并成了一行。

map

這個方法和映射沒有任何關(guān)系,功能是將數(shù)組中的每個元素傳遞給指定的函數(shù)進行處理,并將返回值合成一個數(shù)組返回。

a = [1, 2, 3];

b = a.map(function(value){ return value * 2}); //=>b = [2, 4, 6]

flter

對數(shù)組中的每個元素進行篩選,返回由符合條件的元素構(gòu)成的數(shù)組。

 a = [1, 2, 3, 4, 5, 6, 7]

 b = a.filter(function(x){ return x%2== 0  });  //=>b= [2, 4, 6]

every和some

every方法和some方法對數(shù)組進行邏輯判定。

a = [1, 2, 3, 4, 5];

a.every(fuction(x){ return x > 3 }); //=> false.

這個方法對數(shù)組的所有元素調(diào)用指定的函數(shù),只有所有的(every)結(jié)果都為真,every方法的結(jié)果才為真,否則結(jié)果為假。

a = [1, 2, 3, 4, 5];

a.some(fuction(x){ return x > 3 }); //=> true.

這個方法對數(shù)組的所有元素調(diào)用指定的函數(shù),只要某些(some)結(jié)果為真,some方法的結(jié)果就為真,只有所有的結(jié)果都為假時,結(jié)果才為假。

reduce和reduceRight

reduce方法和reduceRight方法使用指定的函數(shù)將數(shù)組元素進行合并,生成單個值。

a = [1, 2, 3, 4, 5];

factorial = a.reduce(function(prev, v){ return prev * v });

這是一個計算階乘的例子。被指定函數(shù)的兩個參數(shù)一個是前一次計算的結(jié)果,一個是新的元素值。reduce方法會對所有的元素調(diào)用指定函數(shù)。實際上除了函數(shù)以外,reduce還有另外一個參數(shù),用于指定計算的初始值。如果不指定,則使用數(shù)組的第一個元素作為初始值。

reduceRight的功能和reduce類似,只是計算的方向是從后向前。

indexOf和lastIndexOf

indexOf方法搜索數(shù)組中的元素,找到第一個具有給定值的元素的索引值,如果沒有找到,則返回-1??梢允褂每蛇x的第二參數(shù)指定檢索的開始位置。

lastIndexOf的功能和indexOf類似,只是計算的方向是從后向前。

感謝各位的閱讀,以上就是“微信小程序中ECMAScript5數(shù)組操作方法是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對微信小程序中ECMAScript5數(shù)組操作方法是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI