昨天總結的JavaScript中的數組Array方法 數組的迭代方法 ES5中為數組定義了5個迭代方法。每個方法都要接收兩個參數:要在每一項上面運行的函數和(可選的)運行該函數的作用域對象 影響this的值。 傳入方法中的函數會介紹三個參數:1.數組項的值 2. 該項在數組的中位值 3. 數組對象本 ...
數組的迭代方法
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 以此類推