黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > Javascript中的內(nèi)置對象—數(shù)組

Javascript中的內(nèi)置對象—數(shù)組

來源:千鋒教育
發(fā)布人:wjy
時間: 2022-06-01 16:21:00 1654071660

大家好,有關(guān)js中的數(shù)組,很多小伙伴可能都會有疑問,尤其是面試的過程中有大量有關(guān)于原生數(shù)組的題,以及數(shù)組中的方法,及方法的返回值、是否會修改原數(shù)組等等。

想要徹底解決這些問題,就要系統(tǒng)的解析數(shù)組的方法,那么我們今天就來深度解析一下這個問題哈。

## **什么是數(shù)組?**

> 數(shù)組:存儲一組或一系列相關(guān)數(shù)據(jù)的窗口,相當(dāng)于多個變量的組合。(小區(qū))

- 當(dāng)有多個數(shù)據(jù)進行存儲和處理時使用數(shù)組,如果存儲5個、50個數(shù)據(jù)呢?
- 數(shù)組是在內(nèi)存中連續(xù)開辟的空間,相比變量,對于存儲或讀取數(shù)據(jù)的性能更高、更快。

> 數(shù)組下標(biāo):能夠標(biāo)識唯一一個數(shù)組空間的索引號。(相當(dāng)于房間的門牌號)
> 下標(biāo)從0開始,最大下標(biāo):數(shù)組的長度- 1
> 數(shù)組的元素:存儲在數(shù)組中具有唯一索引號中的數(shù)據(jù),叫元素。

Javascript中的內(nèi)置對象—數(shù)組

## **如何聲明數(shù)組?**

1. 字面量方式:[]
2. 構(gòu)造函數(shù)方式:new Array()

```text
var arr = []; //聲明一個空數(shù)組
var list = new Array(); //聲明一個空數(shù)組
```

## **兩種聲明方式的區(qū)別?**

1. 字面量方式,無論存儲什么數(shù)據(jù),都表示數(shù)組元素。
2. 構(gòu)造函數(shù)中有且僅有一個正整數(shù)時,表示數(shù)組長度。
3. 構(gòu)造函數(shù)中有一個負整數(shù)或小數(shù)時,直接報錯
4. 構(gòu)造函數(shù)中有一個或多個其它類型數(shù)據(jù)時,表示數(shù)組元素。

```text
var arr = [5]; // 表示數(shù)組中有一個元素是5,長度是1
var arr = new Array(5); //表示這個數(shù)組的長度為5,可以存放5個元素。默認元素為undefined,undefined,undefined,undefined,undefined
var arr = new Array(-5); //長度不能為負數(shù),程序報錯
var arr = new Array(5.3); //長度不能為小數(shù),程序報錯
var arr = new Array('3'); //表示數(shù)組中有一個元素是'3',長度是1
var arr = new Array(1,2,3,4,5);//表示數(shù)組中有5個元素,分別是1 2 3 4 5 ,長度是5
```

## **如何訪問數(shù)組?**

> 數(shù)組名[下標(biāo)]

```text
var arr = [1,2,3,4,5]; //聲明一個數(shù)組,存放了5個元素
arr[5] = 6; //為數(shù)組新增了一個元素6,下標(biāo)為5
console.log(arr[0]); //訪問數(shù)組中0下標(biāo)對應(yīng)的元素是1
```

## **數(shù)組的屬性**

> length : 表示數(shù)組的長度(即數(shù)組中有多少個內(nèi)存空間)

```text
var arr = [1,2,3,4];
console.log(arr.length); // 4 表示數(shù)組的長度
```

## **數(shù)組的方法(增、刪、改、截、拼、復(fù)、排、轉(zhuǎn))**

**增:**

> unshift(元素,元素,元素,……)

- 作用:在數(shù)組的首部添加新元素。
- 返回值:新增后數(shù)組的長度
- 是否影響原數(shù)組:是

```text
var arr = [5,6,7,8,9]; //聲明一個數(shù)組
console.log(arr.unshift(true,[1,2,3],false)); //unshift方法的返回值,8 表示新增后這個數(shù)組的長度是8
console.log(arr); // 輸出原數(shù)組 [true,[1,2,3],false,5,6,7,8,9]
```

> push(元素,元素,元素,……)

- 作用:在數(shù)組的尾部添加新元素。
- 返回值:新增后數(shù)組的長度
- 是否影響原數(shù)組:是

```text
var arr = [5,6,7,8,9];
console.log(arr.push(true,[1,2,3],false)); //push方法的返回值,8 表示新增后這個數(shù)組的長度是8
console.log(arr); // 輸出原數(shù)組 [5, 6, 7, 8, 9, true, [1,2,3], false]
```

**刪:**

> shift()

- 作用:刪除數(shù)組首部的一個元素( 一次只能刪除一個)
- 返回值:被刪除的元素
- 是否影響原數(shù)組:是

```text
var arr = [5,6,7,8,9];
console.log(arr.shift()); //shift方法的返回值,5 表示在數(shù)組中刪除的元素5
console.log(arr); // 輸出原數(shù)組 [6, 7, 8, 9]
//刪除全部元素
var arr = [5,6,0,8,9];
while(arr.length){
    arr.shift();
}
console.log(arr);
```

> pop()

- 作用:刪除數(shù)組尾部的一個元素( 一次只能刪除一個)
- 返回值:被刪除的元素
- 是否影響原數(shù)組:是

```text
var arr = [5,6,7,8,9];
console.log(arr.pop()); //9 pop方法的返回值,9 表示在數(shù)組中刪除的元素9
console.log(arr); // 輸出原數(shù)組 [5, 6, 7, 8]
```

**改:**

> splice(start,del_length,元素,元素,……)

- start : 從哪個下標(biāo)位置開始
- del_length : 刪除幾個元素
- 元素 :新增的元素
- 作用:在數(shù)組的任意位置可以增、刪、改的操作。
- 返回值:被刪除的元素數(shù)組
- 是否影響原數(shù)組:是

```text
var arr = [5,6,7,8,9];
//只有一個參數(shù)時,表示從指定的下標(biāo)開始刪除到數(shù)組末尾
console.log(arr.splice(1)); // [6, 7, 8, 9] 返回值
console.log(arr); // [5] 原數(shù)組

var arr1 = [5,6,7,8,9];
//兩個參數(shù)時,表示從指定的下標(biāo)位置開始刪除指定長度的元素
console.log(arr1.splice(1,2)); // [6, 7]
console.log(arr1); // [5, 8, 9]

var arr2 = [5,6,7,8,9];
//在刪除的位置新增元素。從下標(biāo)1開始刪除2個元素,并在下標(biāo)1的位置新增true,false兩個元素
console.log(arr2.splice(1,2,true,false)); // [6, 7]
console.log(arr2); // [5, true, false, 8, 9]

var arr3 = [5,6,7,8,9];
//在下標(biāo)1的位置,刪除0個元素,并在下標(biāo)1的位置新增兩個元素true,false
console.log(arr3.splice(1,0,true,false)); // []
console.log(arr3); // [5, true, false, 6, 7, 8, 9]
```

**截:**

> slice(start,end)

- start : 從哪個下標(biāo)位置開始
- end : 到哪個下標(biāo)位置結(jié)束(不包含結(jié)束位置)
- 作用:截取數(shù)組中指定范圍的元素
- 返回值:被截取到的元素數(shù)組
- 是否影響原數(shù)組:否

```text
var arr = [5,6,7,8,9];
// 從原數(shù)組中的下標(biāo)1位置開始截取到數(shù)組末尾,并返回截取到的新數(shù)組
console.log(arr.slice(1)); // [6, 7, 8, 9] 返回值
console.log(arr); // [5,6,7,8,9] 原數(shù)組

var arr1 = [5,6,7,8,9];
//從原數(shù)組中的下標(biāo)1位置開始截取到3下標(biāo)之前(不包含3下標(biāo))
console.log(arr1.slice(1,3)); // [6, 7] 返回值
console.log(arr1); // [5,6,7,8,9] 原數(shù)組

var arr2 = [5,6,7,8,9];
//從原數(shù)組中的下標(biāo)3位置開始截取到1下標(biāo)之前(因為只能向右截取,所有未能截取到元素)
console.log(arr2.slice(3,1)); // [] 返回值
console.log(arr2); // [5,6,7,8,9] 原數(shù)組

var arr3 = [5,6,7,8,9];
//從原數(shù)組中的下標(biāo)-3(最后一個元素下標(biāo)為-1,-3下標(biāo)對應(yīng)的元素為7)位置開始截取到-1下標(biāo)之前(不包含-1下標(biāo))
console.log(arr3.slice(-3,-1)); // [7, 8] 返回值
console.log(arr3); // [5,6,7,8,9] 原數(shù)組
```

**拼:**

> concat(元素,元素,……)

- 作用:在指定的數(shù)組后面拼接新的元素(如果新元素是數(shù)組,則去掉最外層的[]將里面元素拼接)
- 返回值:拼接后的新數(shù)組
- 是否影響原數(shù)組:否

```text
var arr = [5,6,7,8,9];
//拼接的元素如果是多維數(shù)組,則取最外層數(shù)組中的元素原樣拼接到指定數(shù)組的后面
console.log(arr.concat(1,[true,[1,2]],3)); // [5, 6, 7, 8, 9, 1, true, [1,2], 3] 返回值
console.log(arr); // [5,6,7,8,9] 原數(shù)組
```

**復(fù):**

```text
function copyArray(arr){
    return arr.slice(0);
}
function cloneArray(arr){
    return arr.concat();
}
```

**排:**

> reverse()

- 作用:將數(shù)組中的元素逆序存放
- 返回值:返回逆序后的數(shù)組
- 是否影響原數(shù)組:是

```text
var arr = [3,2,10,4,5];
console.log(arr.reverse()); // [5, 4, 10, 2, 3] 返回值
console.log(arr); // [5, 4, 10, 2, 3] 原數(shù)組
```

> sort()

- 作用:將數(shù)組中的元素按照字符編碼進行從小到大排序
- 返回值:返回逆序后的數(shù)組
- 是否影響原數(shù)組:是

```text
var arr = [3,2,10,4,5];
//以字符串的方式比較-排序:10 與 2 比較 1 < 2,所以10 < 2
console.log(arr.sort()); // [10, 2, 3, 4, 5] 返回值
console.log(arr); // [10, 2, 3, 4, 5] 原數(shù)組
```

> sort(function(a,b){return a-b;}) : 將數(shù)組中的元素按照數(shù)字進行從小到大排序。sort(function(a,b){return b-a;}) : 將數(shù)組中的元素按照數(shù)字進行從大到小排序。

```text
var arr = [3,2,10,4,5];
// 按數(shù)字 從小到大
console.log(arr.sort(function(a,b){return a-b;})); //[2, 3, 4, 5, 10]
// 按數(shù)字 從大到小
console.log(arr.sort(function(a,b){return b-a;})); //[10, 5, 4, 3, 2]
```

**轉(zhuǎn):**

> join('連接符')

- 作用:將數(shù)組轉(zhuǎn)為以指定連接符連接成的字符串
- 返回值:返回轉(zhuǎn)換后的字符串
- 是否影響原數(shù)組:否

```text
var arr = [1,2,3,4];
// 將數(shù)組轉(zhuǎn)成以空字符串連接成的字符串
console.log(arr.join('')); //'1234'
```

更多關(guān)于“html5培訓(xùn)”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓(xùn)經(jīng)驗,課程大綱更科學(xué)更專業(yè),有針對零基礎(chǔ)的就業(yè)班,有針對想提升技術(shù)的提升班,高品質(zhì)課程助理你實現(xiàn)夢想。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
国产成人啪精品视频免费软件| 一级女性全黄久久生活片| 欧美电影免费看大全| 亚洲精品影院一区二区| 欧美α片无限看在线观看免费| 欧美一级视频免费| 精品在线免费播放| 国产不卡在线观看| 日本免费区| 亚欧视频在线| 91麻豆高清国产在线播放| 成人免费一级毛片在线播放视频| 天天做日日爱夜夜爽| 精品国产亚洲一区二区三区| 97视频免费在线观看| 四虎影视库| 日韩在线观看视频免费| 毛片成人永久免费视频| 99色视频在线| 色综合久久天天综合观看| 色综合久久久久综合体桃花网| 黄视频网站在线免费观看| 午夜在线影院| 欧美电影免费| 高清一级淫片a级中文字幕| 久久久久久久男人的天堂| 国产一区二区精品尤物| 国产欧美精品| 精品在线观看国产| 日日夜夜婷婷| 欧美激情一区二区三区视频 | 国产91精品一区二区| 精品在线免费播放| 日本免费乱理伦片在线观看2018| 精品视频一区二区三区免费| 免费国产在线观看不卡| 国产一级生活片| 九九久久99| 精品视频免费在线| 99久久精品费精品国产一区二区| 午夜在线亚洲男人午在线| 国产麻豆精品免费视频| 午夜久久网| 国产高清在线精品一区a| 亚洲精品久久玖玖玖玖| 日本免费乱人伦在线观看| 毛片高清| 精品久久久久久中文| 精品视频在线观看一区二区| 天堂网中文在线| 国产福利免费视频| 国产综合成人观看在线| 久久久久久久男人的天堂| 国产福利免费观看| 九九久久国产精品| 国产一区免费在线观看| 精品国产亚洲人成在线| 免费国产在线视频| 国产麻豆精品视频| 久久国产一区二区| 青青久久精品| 日本免费区| 超级乱淫伦动漫| 青草国产在线观看| 91麻豆精品国产自产在线| 91麻豆爱豆果冻天美星空| 免费一级片在线| 99久久精品国产高清一区二区| 韩国三级香港三级日本三级| 欧美激情一区二区三区在线 | 青草国产在线观看| 欧美国产日韩精品| 免费毛片播放| 成人影视在线观看| 韩国毛片| 欧美一级视频高清片| 国产91丝袜高跟系列| 亚洲 国产精品 日韩| 91麻豆精品国产自产在线| 色综合久久天天综合观看| 久久国产影视免费精品| 国产欧美精品| 精品视频在线观看一区二区| 日韩一级黄色| 久久精品免视看国产成人2021| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品国产一级毛片| 精品视频一区二区三区| 精品视频在线观看一区二区三区| 国产麻豆精品hdvideoss| 成人免费一级纶理片| 日韩男人天堂| 精品在线免费播放| 可以免费在线看黄的网站| 99久久视频| 日本伦理片网站| 亚欧成人乱码一区二区| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产网站在线| 天天做日日爱夜夜爽| 成人高清视频免费观看| 四虎影视久久久免费| 久久国产一久久高清| 国产亚洲免费观看| 天堂网中文字幕| 国产成人精品综合久久久| 国产一区免费在线观看| 国产网站免费| 国产麻豆精品免费视频| 四虎影视久久| 欧美国产日韩久久久| 九九九国产| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 你懂的日韩| 久久国产精品自由自在| 台湾毛片| 一级女性全黄久久生活片| 免费国产在线观看不卡| 成人在免费观看视频国产| 精品国产亚洲人成在线| 人人干人人插| 99色视频在线观看| 国产一区二区精品尤物| 国产91素人搭讪系列天堂| 久久99欧美| 精品国产三级a∨在线观看| 成人a大片在线观看| 精品国产三级a∨在线观看| 国产高清在线精品一区a| 久久99中文字幕久久| 精品国产香蕉在线播出| 国产不卡在线看| 亚洲精品久久玖玖玖玖| 精品国产一区二区三区精东影业| 欧美1区2区3区| 欧美激情在线精品video| 天天做人人爱夜夜爽2020毛片| 亚洲精品影院| 国产成人啪精品视频免费软件| 黄色福利| 国产国语对白一级毛片| 日本特黄一级| 精品视频在线看| 可以在线看黄的网站| a级精品九九九大片免费看| 久久精品欧美一区二区| 国产福利免费视频| 国产麻豆精品高清在线播放| 精品毛片视频| 国产不卡福利| 国产成人精品影视| 99热精品一区| 久久国产一久久高清| 欧美大片a一级毛片视频| 欧美另类videosbestsex高清| 亚洲精品影院| 国产网站在线| 青青久热| 日韩专区第一页| 欧美爱色| 91麻豆精品国产综合久久久| 美女被草网站| 91麻豆精品国产自产在线观看一区| 天天色成人网| 毛片高清| 国产一区精品| 欧美a级片免费看| 四虎久久精品国产| 精品视频在线观看免费| 国产成人精品综合| 99热视热频这里只有精品| 国产一区二区精品尤物| 国产欧美精品| 欧美一级视频免费| 日本免费区| 欧美激情影院| 美女免费毛片| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 天天色成人网| 成人影院一区二区三区| 色综合久久天天综线观看| 欧美另类videosbestsex高清| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 久草免费在线观看| 久久久久久久网| 国产一区二区精品久| 青青久热| 国产视频一区在线| 韩国三级香港三级日本三级la | 国产麻豆精品免费视频| 高清一级淫片a级中文字幕| 台湾毛片| 黄视频网站免费观看| a级毛片免费全部播放| 你懂的国产精品| 亚洲精品永久一区| 精品在线观看国产| 二级片在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美日本国产|