1.map
map 方法可以方便的迭代數組,例子:
var timesFour = oldArray.map(function(val){ return val * 4;});
map方法會迭代數組中的每一個元素,并根據回調函數來處理每一個元素,最后返回一個新數組。注意,這個方法不會改變原始數組。
在我們的例子中,回調函數只有一個參數,即數組中元素的值 (val 參數) ,但其實,你的回調函數也可以支持多個參數,譬如:元素的索引index、原始數組arr。
2.reduce
數組方法 reduce 用來迭代一個數組,并且把它累積到一個值中。
使用 reduce 方法時,你要傳入一個回調函數,這個回調函數的參數是一個累加器(比如例子中的previousVal)和當前值(currentVal)。
reduce方法有一個可選的第二參數,它可以被用來設置累加器的初始值。如果沒有在這定義初始值,那么初始值將變成數組中的第一項,而 currentVal 將從數組的第二項開始。
下面的例子使用了 reduce 來讓數組中的所有值相減:
var singleVal = array.reduce(function(previousVal, currentVal) { return previousVal - currentVal;}, 0);
3.filter
filter方法用來迭代一個數組,并且按給出的條件過濾出符合的元素。
filter方法傳入一個回調函數,這個回調函數會攜帶一個參數,參數為當前迭代的項(我們叫它 val )。
回調函數返回 true 的項會保留在數組中,返回 false 的項會被過濾出數組。
下面的代碼示例展示了使用 filter 來移除數組中值等于5的項:
注意: 我們忽略了第二參數和第三參數,因為例子中我們只需要第一參數就夠了。
array = array.filter(function(val) { return val !== 5;});
4.sort
使用sort方法,你可以很容易的按字母順序或數字順序對數組中的元素進行排序。
與我們之前用的數組方法僅僅返回一個新數組不同, sort 方法將改變原數組,返回被排序后的數組。
sort 可以把比較函數作為參數傳入。比較函數有返回值,當 a 小于 b,返回一個負數;當 a 大于 b ,返回一個正數;相等時返回0。
如果沒有傳入比較函數,它將把值全部轉成字符串,并按照字母順序進行排序。
下面的例子將展示sort的使用,傳入的比較函數把元素按照從小到大的順序進行排列:
var array = [1, 12, 21, 2];array.sort(function(a, b) { return a - b;});
5.reverse
你可以使用 reverse 方法來翻轉數組。
var myArray = [1, 2, 3];myArray.reverse();
結果myArray 變成了 [3, 2, 1]。
6.concat
concat 方法可以用來把兩個數組的內容合并到一個數組中。
concat方法的參數應該是一個數組。參數中的數組會拼接在原數組的后面,并作為一個新數組返回。
下面是一個拼接數組的例子,用concat把otherArray拼接在oldArray 的后面:
newArray = oldArray.concat(otherArray);
7.split
你可以使用 split 方法按指定分隔符將字符串分割為數組。
你要給 split 方法傳遞一個參數,這個參數將會作為一個分隔符。
下面的例子展示了 split 方法的使用,按照 s 字母進行分割:
var array = string.split('s');
如果有這樣一個字符串:”jb51.net,google.com,baidu.com_weibo.com_haotu.net”,
我們希望同時按照逗號和下劃線對網站地址進行分割,參考下面的代碼:
var mystring = "jb51.net,google.com,baidu.com_weibo.com_haotu.net";var myarray = mystring.split(/[,_]/);
8.join
我們還可以使用 join 方法來把數組轉換成字符串,里面的每一個元素可以用你指定的連接符來連接起來,這個連接符就是你要傳入的參數。
下面展示了使用 join 來將數組中的每一項放入字符串,并用 and 進行連接:
var veggies = ["Celery", "Radish", "Carrot", "Potato"];var salad = veggies.join(" and ");console.log(salad); // "Celery and Radish and Carrot and Potato"
看文倉www.kanwencang.com網友整理上傳,為您提供最全的知識大全,期待您的分享,轉載請注明出處。
歡迎轉載:http://www.kanwencang.com/bangong/20170301/108580.html
文章列表