您好,登錄后才能下訂單哦!
這篇文章主要講解了“微信小程序中ECMAScript5數組操作方法是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“微信小程序中ECMAScript5數組操作方法是什么”吧!
首先補充說明一下,ECMAScript是歐洲計算機制造商協會(European Computer Manufacturers Association)為了統一各種script,以JavaScript1.1為基礎搞出來的一種腳本語言規范。ECMAScript5是這個規范第五個版本。由于它得到了各大瀏覽器廠商的響應積極,所以稱得上是JavaScript的未來。微信小程序也支持ECMAScript5。
ECMASript5中的數組方法
forEach
forEach方法提供了一種相對簡單的(至少是在形式上)方法遍歷數組,它有3個參數:數組元素,元素的索引和數組本身。
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為例,稍微展開說明。代碼可能不能執行,只是為了說明。
forEach的實現大致如下,想象的,偏差應該不大。
function forEach(f)
{
for(int i = 0; i < array.length; i++)
f(array[i], i, array);
}
用戶定義一個函數,參數為數組元素,元素的索引和數組本身。之所以這樣定義是forEach方法實現的要求。
function mul2(v, i, a)
{
a[i] = v * 2;
}
接下來是調用
data.forEach(mul2);
這樣就好理解多了。示例中只是將定義乘2函數和調用該函數合并成了一行。
map
這個方法和映射沒有任何關系,功能是將數組中的每個元素傳遞給指定的函數進行處理,并將返回值合成一個數組返回。
a = [1, 2, 3];
b = a.map(function(value){ return value * 2}); //=>b = [2, 4, 6]
flter
對數組中的每個元素進行篩選,返回由符合條件的元素構成的數組。
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方法對數組進行邏輯判定。
a = [1, 2, 3, 4, 5];
a.every(fuction(x){ return x > 3 }); //=> false.
這個方法對數組的所有元素調用指定的函數,只有所有的(every)結果都為真,every方法的結果才為真,否則結果為假。
a = [1, 2, 3, 4, 5];
a.some(fuction(x){ return x > 3 }); //=> true.
這個方法對數組的所有元素調用指定的函數,只要某些(some)結果為真,some方法的結果就為真,只有所有的結果都為假時,結果才為假。
reduce和reduceRight
reduce方法和reduceRight方法使用指定的函數將數組元素進行合并,生成單個值。
a = [1, 2, 3, 4, 5];
factorial = a.reduce(function(prev, v){ return prev * v });
這是一個計算階乘的例子。被指定函數的兩個參數一個是前一次計算的結果,一個是新的元素值。reduce方法會對所有的元素調用指定函數。實際上除了函數以外,reduce還有另外一個參數,用于指定計算的初始值。如果不指定,則使用數組的第一個元素作為初始值。
reduceRight的功能和reduce類似,只是計算的方向是從后向前。
indexOf和lastIndexOf
indexOf方法搜索數組中的元素,找到第一個具有給定值的元素的索引值,如果沒有找到,則返回-1。可以使用可選的第二參數指定檢索的開始位置。
lastIndexOf的功能和indexOf類似,只是計算的方向是從后向前。
感謝各位的閱讀,以上就是“微信小程序中ECMAScript5數組操作方法是什么”的內容了,經過本文的學習后,相信大家對微信小程序中ECMAScript5數組操作方法是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。