400-650-7353
您所在的位置:首頁 > IT干貨資料 > web前端 > 【W(wǎng)eb前端基礎(chǔ)知識(shí)】Array數(shù)組函數(shù)實(shí)例方法

【W(wǎng)eb前端基礎(chǔ)知識(shí)】Array數(shù)組函數(shù)實(shí)例方法

  • 發(fā)布: Web前端培訓(xùn)
  • 來源:Web前端培訓(xùn)問答
  • 2021-02-25 10:31:21
  • 閱讀()
  • 分享
  • 手機(jī)端入口

valueOf(),toString()

valueOf方法是一個(gè)所有對(duì)象都擁有的方法,表示對(duì)該對(duì)象求值。不同對(duì)象的valueOf方法不盡一致,數(shù)組的valueOf方法返回?cái)?shù)組本身。

toString方法也是對(duì)象的通用方法,數(shù)組的toString方法返回?cái)?shù)組的字符串形式。

  1. var arr = [1, 2, 3]; 
  2. arr.toString() // "1,2,3" 

push(),pop()

push方法用于在數(shù)組的末端添加一個(gè)或多個(gè)元素,并返回添加新元素后的數(shù)組長(zhǎng)度。注意,該方法會(huì)改變?cè)瓟?shù)組。

  1. var arr = []; 
  2. arr.push(1);  
  3. arr.push('a'); 
  4. arr.push(true, {})  
  5. console.log(arr); // [1, 'a', true, {}] 

上面代碼使用push方法,往數(shù)組中添加了四個(gè)成員。

pop方法用于刪除數(shù)組的最后一個(gè)元素,并返回該元素。注意,該方法會(huì)改變?cè)瓟?shù)組。

  1. var arr = [1, 2, 3]; 
  2. ​ 
  3. console.log(arr.pop()); // 3 
  4. console.log(arr); // ['a', 'b'] 

對(duì)空數(shù)組使用pop方法,不會(huì)報(bào)錯(cuò),而是返回undefined。

shift(),unshift()

shift()方法用于刪除數(shù)組的第一個(gè)元素,并返回該元素。注意,該方法會(huì)改變?cè)瓟?shù)組。

  1. var arr = ['a', 'b', 'c']; 
  2. arr.shift(); // 'a' 
  3. arr; // ['b', 'c'] 

上面代碼中,使用shift()方法以后,原數(shù)組就變了。

unshift()方法用于在數(shù)組的第一個(gè)位置添加元素,并返回添加新元素后的數(shù)組長(zhǎng)度。注意,該方法會(huì)改變?cè)瓟?shù)組。

  1. var arr = ['a', 'b', 'c']; 
  2. arr.unshift('x'); // 4 
  3. arr; // ['x', 'a', 'b', 'c'] 

unshift()方法可以接受多個(gè)參數(shù),這些參數(shù)都會(huì)添加到目標(biāo)數(shù)組頭部。

  1. var arr = [ 'c', 'd' ]; 
  2. arr.unshift('a', 'b') // 4 
  3. arr // [ 'a', 'b', 'c', 'd' ] 

join()

join()方法以指定參數(shù)作為分隔符,將所有數(shù)組成員連接為一個(gè)字符串返回。如果不提供參數(shù),默認(rèn)用逗號(hào)分隔。

  1. var a = [1, 2, 3, 4]; 
  2. a.join(' ') // '1 2 3 4' 
  3. a.join(' | ') // "1 | 2 | 3 | 4" 
  4. a.join() // "1,2,3,4" 

concat()

concat方法用于多個(gè)數(shù)組的合并。它將新數(shù)組的成員,添加到原數(shù)組成員的后部,然后返回一個(gè)新數(shù)組,原數(shù)組不變。

  1. ['hello'].concat(['world']); // ["hello", "world"] 
  2. ['hello'].concat(['world'], ['!']);// ["hello", "world", "!"] 

除了數(shù)組作為參數(shù),concat也接受其他類型的值作為參數(shù),添加到目標(biāo)數(shù)組尾部。

  1. [1, 2, 3].concat(4, 5, 6); // [1, 2, 3, 4, 5, 6] 

reverse()

reverse方法用于顛倒排列數(shù)組元素,返回改變后的數(shù)組。注意,該方法將改變?cè)瓟?shù)組。

  1. var a = ['a', 'b', 'c']; 
  2. a.reverse(); // ["c", "b", "a"] 
  3. a; // ["c", "b", "a"] 

slice()

slice()方法用于提取目標(biāo)數(shù)組的一部分,返回一個(gè)新數(shù)組,原數(shù)組不變。 arr.slice(start, end);

它的第一個(gè)參數(shù)為起始位置(從0開始,會(huì)包括在返回的新數(shù)組之中),第二個(gè)參數(shù)為終止位置(但該位置的元素本身不包括在內(nèi))。如果省略第二個(gè)參數(shù),則一直返回到原數(shù)組的最后一個(gè)成員。

  1. var a = ['a', 'b', 'c']; 
  2. a.slice(0); // ["a", "b", "c"] 
  3. a.slice(1); // ["b", "c"] 
  4. a.slice(1, 2); // ["b"] 
  5. a.slice(2, 6); // ["c"] 
  6. a.slice(); // ["a", "b", "c"] 

如果slice()方法的參數(shù)是負(fù)數(shù),則表示倒數(shù)計(jì)算的位置。

splice()

splice()方法用于刪除原數(shù)組的一部分成員,并可以在刪除的位置添加新的數(shù)組成員,返回值是被刪除的元素。注意,該方法會(huì)改變?cè)瓟?shù)組。arr.splice(start, count, addElement1, addElement2, ...);

splice的第一個(gè)參數(shù)是刪除的起始位置(從0開始),第二個(gè)參數(shù)是被刪除的元素個(gè)數(shù)。如果后面還有更多的參數(shù),則表示這些就是要被插入數(shù)組的新元素。

  1. var a = ['a', 'b', 'c', 'd', 'e', 'f']; 
  2. a.splice(4, 2); // ["e", "f"] 
  3. a; // ["a", "b", "c", "d"] 

上面代碼從原數(shù)組4號(hào)位置,刪除了兩個(gè)數(shù)組成員。

  1. var a = ['a', 'b', 'c', 'd', 'e', 'f']; 
  2. a.splice(4, 2, 1, 2); // ["e", "f"] 
  3. a; // ["a", "b", "c", "d", 1, 2] 

上面代碼除了刪除成員,還插入了兩個(gè)新成員。

起始位置如果是負(fù)數(shù),就表示從倒數(shù)位置開始刪除。

  1. var a = ['a', 'b', 'c', 'd', 'e', 'f']; 
  2. a.splice(-4, 2); // ["c", "d"] 

上面代碼表示,從倒數(shù)第四個(gè)位置c開始刪除兩個(gè)成員。

如果只是單純地插入元素,splice方法的第二個(gè)參數(shù)可以設(shè)為0。

  1. var a = [1, 1, 1]; 
  2. a.splice(1, 0, 2); // [] 
  3. a; // [1, 2, 1, 1] 

如果只提供第一個(gè)參數(shù),等同于將原數(shù)組在指定位置拆分成兩個(gè)數(shù)組。

  1. var a = [1, 2, 3, 4]; 
  2. a.splice(2); // [3, 4] 
  3. a; // [1, 2] 

sort()

sort方法對(duì)數(shù)組成員進(jìn)行排序,默認(rèn)是按照字典順序排序。排序后,原數(shù)組將被改變。

  1. ['d', 'c', 'b', 'a'].sort() 
  2. // ['a', 'b', 'c', 'd'] 
  3.  
  4. [4, 3, 2, 1].sort() 
  5. // [1, 2, 3, 4] 
  6.  
  7. [11, 101].sort() 
  8. // [101, 11] 
  9.  
  10. [10111, 1101, 111].sort() 
  11. // [10111, 1101, 111] 

上面代碼的最后兩個(gè)例子,需要特殊注意。sort()方法不是按照大小排序,而是按照字典順序。也就是說,數(shù)值會(huì)被先轉(zhuǎn)成字符串,再按照字典順序進(jìn)行比較,所以101排在11的前面。

如果想讓sort方法按照自定義方式排序,可以傳入一個(gè)函數(shù)作為參數(shù)。

  1. [10111, 1101, 111].sort(function (a, b) { 
  2.   return a - b; 
  3. }) 
  4. // [111, 1101, 10111] 

上面代碼中,sort的參數(shù)函數(shù)本身接受兩個(gè)參數(shù),表示進(jìn)行比較的兩個(gè)數(shù)組成員。如果該函數(shù)的返回值大于0,表示第一個(gè)成員排在第二個(gè)成員后面;其他情況下,都是第一個(gè)元素排在第二個(gè)元素前面。

  1.   { name: "張三", age: 30 }, 
  2.   { name: "李四", age: 24 }, 
  3.   { name: "王五", age: 28  } 
  4. ].sort(function (o1, o2) { 
  5.   return o1.age - o2.age; 
  6. }) 
  7. // [ 
  8. //   { name: "李四", age: 24 }, 
  9. //   { name: "王五", age: 28  }, 
  10. //   { name: "張三", age: 30 } 
  11. // ] 

注意,自定義的排序函數(shù)應(yīng)該返回?cái)?shù)值,否則不同的瀏覽器可能有不同的實(shí)現(xiàn),不能保證結(jié)果都一致。

以上是對(duì)數(shù)組創(chuàng)建方式和常用方法的描述,希望可以讓你對(duì)數(shù)組有清晰的了解。

文章“【W(wǎng)eb前端基礎(chǔ)知識(shí)】Array數(shù)組函數(shù)實(shí)例方法”已幫助

>>本文地址:http://hqfphsz.com/zhuanye/2021/67119.html

THE END  

聲明:本站稿件版權(quán)均屬中公教育優(yōu)就業(yè)所有,未經(jīng)許可不得擅自轉(zhuǎn)載。

1 您的年齡

2 您的學(xué)歷

3 您更想做哪個(gè)方向的工作?

獲取測(cè)試結(jié)果
  • 大前端大前端
  • 大數(shù)據(jù)大數(shù)據(jù)
  • 互聯(lián)網(wǎng)營(yíng)銷互聯(lián)網(wǎng)營(yíng)銷
  • JavaJava
  • Linux云計(jì)算Linux
  • Python+人工智能Python
  • 嵌入式物聯(lián)網(wǎng)嵌入式
  • 全域電商運(yùn)營(yíng)全域電商運(yùn)營(yíng)
  • 軟件測(cè)試軟件測(cè)試
  • 室內(nèi)設(shè)計(jì)室內(nèi)設(shè)計(jì)
  • 平面設(shè)計(jì)平面設(shè)計(jì)
  • 電商設(shè)計(jì)電商設(shè)計(jì)
  • 網(wǎng)頁設(shè)計(jì)網(wǎng)頁設(shè)計(jì)
  • 全鏈路UI/UE設(shè)計(jì)UI設(shè)計(jì)
  • VR/AR游戲開發(fā)VR/AR
  • 網(wǎng)絡(luò)安全網(wǎng)絡(luò)安全
  • 新媒體與短視頻運(yùn)營(yíng)新媒體
  • 直播帶貨直播帶貨
  • 智能機(jī)器人軟件開發(fā)智能機(jī)器人
 

快速通道fast track

近期開班時(shí)間TIME