JS學習筆記_數(shù)組篇

(一)操作方法

push: 從數(shù)組末尾添加項,返回數(shù)組長度
unshift : 從數(shù)組頭添加項郁副,返回數(shù)組長度
pop : 從數(shù)組末尾刪除項碾篡,返回被移除的項
shift : 從數(shù)組頭刪除項铡羡,返回被移除的項
concat : 組合兩個數(shù)組拭嫁,原來的數(shù)組不會被改變
slice : 接受一個或兩個參數(shù),從數(shù)組中截取部分項浮入,返回新的數(shù)組龙优,原來的數(shù)組不會被改變

注意: 如果結(jié)束位置小于初始位置則返回空的數(shù)組;如果參數(shù)為負值事秀,則位置是 參數(shù)+數(shù)組長度

splice => 有三種基本用法:

  • 刪除項: 第一個參數(shù)表示開始刪除項的位置彤断,第二個參數(shù)表示要刪除多少項
  • 插入項: 第一個參數(shù)表示開始刪除項的位置,第二個參數(shù)表示要是出多少項(這里是0易迹,表示不刪除),第三個參數(shù)表示要插入的項宰衙,如果要插入多個項,可以添加第四個睹欲,第五個參數(shù)
  • 替換項: 第一個參數(shù)表示開始刪除項的位置供炼,第二個參數(shù)表示要刪除多少項,第三個參數(shù)表示要替換的項窘疮,如果替換的項有多個袋哼,同上。

(二)排序

sort => 先把數(shù)組的每個值用 toString()方法轉(zhuǎn)成字符串考余,然后再比較
所以要想得到正確的順序先嬉,需要給sort傳遞一個比較函數(shù)轧苫,推薦一個比較常用的比較函數(shù):

function compare(v1,v2){
return v2 - v1
}
用法:sort(compare)

(三)位置

indexOf => 查找某個項在數(shù)組中的位置楚堤,從頭查詢疫蔓。
lastIndexOf => 查找某個項在數(shù)組中的位置,從末尾查詢身冬。

以上兩個方法都接受兩個參數(shù)衅胀,第一個參數(shù)表示要查詢的項,第二個參數(shù)表示開始查詢位置(可選)

(四)迭代方法

五個迭代方法接受兩個參數(shù)酥筝,一個是要數(shù)組對象滚躯,一個是運行在數(shù)組每一項上的函數(shù)

  1. every() => 如果函數(shù)每一項都返回true,則返回值為true
var numbers = [1,2,3,4]
var result = numbers.every(function(item, index, array){
  return (item > 2)
})
console.log(result) // false

2.some() => 如果函數(shù)中任一項返回true嘿歌,則返回值為true

var numbers = [1,2,3,4]
var result = numbers.some(function(item, index, array){
  return (item > 2)
})
console.log(result) // true

3.filter() => 函數(shù)中返回值為true的項組成新數(shù)組

var numbers = [1,2,3,4]
var result = numbers.filter(function(item, index, array){
  return (item > 2)
})
console.log(result) // [3,4]

4.map() => 每次調(diào)用函數(shù)的結(jié)果組成新的數(shù)組

var numbers = [1,2,3,4]
var result = numbers.map(function(item, index, array){
  return item * 2
})
console.log(result) // [2,4,6,8]

5.forEach() => 這個方法沒有返回值

var numbers = [1,2,3,4]
 numbers.map(function(item, index, array){
  // 執(zhí)行某些操作
})

6.reduce()reduceRight() ,其實這兩個方法不是迭代方法掸掏,為了方便我整理到了一起,解釋起來比較麻煩,看列子會明白:

// 計算一個數(shù)組的求和
var arr = [1,2,3,4]
var sum = arr.reduce(function(prev,cur,index,array){
  return prev + cur
})
console.log(sum)  // 10
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末宙帝,一起剝皮案震驚了整個濱河市丧凤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌步脓,老刑警劉巖愿待,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異靴患,居然都是意外死亡仍侥,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進店門鸳君,熙熙樓的掌柜王于貴愁眉苦臉地迎上來农渊,“玉大人,你說我怎么就攤上這事或颊⊥仁保” “怎么了?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵饭宾,是天一觀的道長批糟。 經(jīng)常有香客問我,道長看铆,這世上最難降的妖魔是什么徽鼎? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮弹惦,結(jié)果婚禮上否淤,老公的妹妹穿的比我還像新娘。我一直安慰自己棠隐,他們只是感情好石抡,可當我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著助泽,像睡著了一般啰扛。 火紅的嫁衣襯著肌膚如雪嚎京。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天隐解,我揣著相機與錄音鞍帝,去河邊找鬼。 笑死煞茫,一個胖子當著我的面吹牛帕涌,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播续徽,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼蚓曼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了钦扭?” 一聲冷哼從身側(cè)響起辟躏,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎土全,沒想到半個月后捎琐,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡裹匙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年瑞凑,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片概页。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡籽御,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出惰匙,到底是詐尸還是另有隱情技掏,我是刑警寧澤,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布项鬼,位于F島的核電站哑梳,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏绘盟。R本人自食惡果不足惜鸠真,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望龄毡。 院中可真熱鬧吠卷,春花似錦、人聲如沸沦零。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽路操。三九已至疾渴,卻和暖如春千贯,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背程奠。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留祭钉,地道東北人瞄沙。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像慌核,于是被迫代替她去往敵國和親距境。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,440評論 2 348

推薦閱讀更多精彩內(nèi)容