您好,登錄后才能下訂單哦!
本篇內容介紹了“JS中數組的迭代方法和歸并方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
數組的迭代方法
ES5中為數組定義了5個迭代方法。每個方法都要接收兩個參數:要在每一項上面運行的函數和(可選的)運行該函數的作用域對象---影響this的值。
傳入方法中的函數會介紹三個參數:1.數組項的值 2. 該項在數組的中位值 3. 數組對象本身;
every()和some()方法
every():對數組中的每一項運行給定函數,如果每一項都返回true,則返回true,否則false;
some():對數組中的每一項運行給定函數,如果至少有一項返回true,則返回true,否則false;
var arr=[1,2,4,5,3,1]; var one=arr.every(function(item,index,array){ return (item>2); }); console.log(one); //false var two=arr.some(function(item,index,array){ return (item>2); }); console.log(two); //true
filter()和map()方法
filter():對數組中的每一項給定函數,返回值為true的項重新組成新的數組;
map():歲數組中的每一項給定函數,返回每一項調用這個函數的結果;
//數組中可以被2整除的數 var arr=[1,2,4,5,3,1]; var one=arr.filter(function(item,index,array){ return (item%2==0); }); console.log(one); //[2, 4] //數組中所有數的2倍 var two=arr.map(function(item,index,array){ return (item*2); }); console.log(two); //[2, 4, 8, 10, 6, 2]
forEach()方法
forEach():對方法中的每一項運行給定函數。這個方法沒有返回值;
var a = ['a', 'b', 'c']; a.forEach(function(item,index,array) { console.log(item); }); // "a" // "b" // "c"
歸并方法
reduce()和reduceRight()方法
var nums=[1,2,3,4,5]; var sum=nums.reduce(function(prev,cur,index,array){ return prev+cur; }); alert(sum); //15 第一次 prev:1;cur:2; 第二次: prev:3(1+2) cur:3 以此類推 /******************************************************************************************/ var nums=[1,2,3,4,5]; var sum=nums.reduceRight(function(prev,cur,index,array){ return prev+cur; }); alert(sum); //15 第一次 prev:5;cur:4; 第二次: prev:9(5+4) cur:3 以此類推
“JS中數組的迭代方法和歸并方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。