日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

js中的数组方法

發布時間:2024/8/5 综合教程 35 生活家
生活随笔 收集整理的這篇文章主要介紹了 js中的数组方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

數組的方法有數組原型方法,也有從object對象繼承來的方法,這里我們只介紹數組的原型方法,數組原型方法主要有以下這些:

join()
push()和pop()
shift() 和 unshift()
sort()
reverse()
concat()
slice()
splice()
indexOf()和 lastIndexOf() (ES5新增)
forEach() (ES5新增)
map() (ES5新增)
filter() (ES5新增)
every() (ES5新增)
some() (ES5新增)
reduce()和 reduceRight() (ES5新增)

1、join()

將指定數組轉化成字符串,方法中的參數實際就是將數組中元素拼接成字符串的分隔符,參數省略則默認以逗號作為分隔符

2、push()和pop()

push:向指定數組的末尾添加元素,可以有多個參數,返回值為添加后數組的長度

pop():刪除指定數組的末尾元素,pop沒有參數,每次調用只能刪除末尾的一個元素,返回值為刪掉的那個元素;

var list=["蘋果","橘子","香蕉","西瓜","櫻桃"];

var count=list.push("荔枝","藍莓");

var list=["蘋果","橘子","香蕉","西瓜","櫻桃"];

console.log(list) //["蘋果", "橘子", "香蕉", "西瓜", "櫻桃", "荔枝", "藍莓"]

console.log(count) //7

var a=list.pop();
console.log(list); //["蘋果", "橘子", "香蕉", "西瓜", "櫻桃", "荔枝"]
console.log(a); //藍莓

3、shift() 和 unshift()

shift():刪除原數組第一項,沒有參數,并返回刪除元素的值;如果數組為空則返回undefined 。
unshift:將參數添加到原數組開頭,可以添加多個參數,并返回數組的長度 。

4、sort()

sort():按升序排列數組項——即最小的值位于最前面,最大的值排在最后面。

5、reverse()

reverse():反轉數組項的順序。

6、concat()

concat() :將參數添加到原數組中。這個方法會先創建當前數組一個副本,然后將接收到的參數添加到這個副本的末尾,最后返回新構建的數組。在沒有給 concat()方法傳遞參數的情況下,它只是復制當前數組并返回副本。

7、slice()

slice():返回從原數組中指定開始下標到結束下標之間的項組成的新數組。slice()方法可以接受一或兩個參數,即要返回項的起始和結束位置。在只有一個參數的情況下, slice()方法返回從該參數指定位置開始到當前數組末尾的所有項。如果有兩個參數,該方法返回起始和結束位置之間的項——但不包括結束位置的項。

1
2
3
4
5
6
7
8
9
10

vararr = [1,3,5,7,9,11];
vararrCopy = arr.slice(1);
vararrCopy2 = arr.slice(1,4);
vararrCopy3 = arr.slice(1,-2);
vararrCopy4 = arr.slice(-4,-1);
console.log(arr); //[1, 3, 5, 7, 9, 11](原數組沒變)
console.log(arrCopy); //[3, 5, 7, 9, 11]
console.log(arrCopy2); //[3, 5, 7]
console.log(arrCopy3); //[3, 5, 7]
console.log(arrCopy4); //[5, 7, 9]

arrCopy只設置了一個參數,也就是起始下標為1,所以返回的數組為下標1(包括下標1)開始到數組最后。
arrCopy2設置了兩個參數,返回起始下標(包括1)開始到終止下標(不包括4)的子數組。
arrCopy3設置了兩個參數,終止下標為負數,當出現負數時,將負數加上數組長度的值(6)來替換該位置的數,因此就是從1開始到4(不包括)的子數組。
arrCopy4中兩個參數都是負數,所以都加上數組長度6轉換成正數,因此相當于slice(2,5)。

8、splice()

splice():很強大的數組方法,它有很多種用法,可以實現刪除、插入和替換。

1-添加元素:第一個參數表示從那個下標位置開始添加,第二個參數為0,第三個參數表示要添加的元素可以存在多個

2、替換元素:第一個參數表示從那個下標位置開始添加(包含下標開始的位置),第二個參數表示替換的長度,第三個參數表示用什么元素替換

3-刪除元素
第一個參數為開始刪除的下標位置,第二個參數為刪除的長度,第三個參數不填寫

9、indexOf()和 lastIndexOf()

用來判斷數組中是否存在某個元素,如果存在,返回該元素的下標,如果不存在返回-1,前者是從數組的開向后查找,后者是從數組的末尾向前查找

10、forEach()

forEach():對數組進行遍歷循環,對數組中的每一項運行給定函數。這個方法沒有返回值。參數都是function類型,默認有傳參,參數分別為:遍歷的數組內容;內容對應的數組索引,數組本身。

vararr = [1, 2, 3, 4, 5];

arr.forEach(function(x, index, a){
console.log(x + '|'+ index + '|'+ (a === arr));
});
// 輸出為:
// 1|0|true
// 2|1|true
// 3|2|true
// 4|3|true
// 5|4|true

11、map()

map():指“映射”,對數組中的每一項運行給定函數,返回每次函數調用的結果組成的數組。

下面代碼利用map方法實現數組中每個數求平方。

1
2
3
4
5

vararr = [1, 2, 3, 4, 5];
vararr2 = arr.map(function(item){
returnitem*item;
});
console.log(arr2); //[1, 4, 9, 16, 25]

12、filter()

filter():“過濾”功能,數組中的每一項運行給定函數,返回滿足過濾條件組成的數組。

1
2
3
4
5

vararr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
vararr2 = arr.filter(function(x, index) {
returnindex % 3 === 0 || x >= 8;
});
console.log(arr2); //[1, 4, 7, 8, 9, 10]

13、every()

every():判斷數組中每一項都是否滿足條件,只有所有項都滿足條件,才會返回true。

vararr = [1, 2, 3, 4, 5];

vararr2 = arr.every(function(x) {
returnx < 10;
});
console.log(arr2); //true

14、some()

some():判斷數組中是否存在滿足條件的項,只要有一項滿足條件,就會返回true。

vararr = [1, 2, 3, 4, 5];

vararr2 = arr.some(function(x) {
returnx < 3;
});
console.log(arr2); //true

15、reduce()和 reduceRight()

這兩個方法都會實現迭代數組的所有項,然后構建一個最終返回的值。reduce()方法從數組的第一項開始,逐個遍歷到最后。而 reduceRight()則從數組的最后一項開始,向前遍歷到第一項。

這兩個方法都接收兩個參數:一個在每一項上調用的函數和(可選的)作為歸并基礎的初始值。

傳給 reduce()和 reduceRight()的函數接收 4 個參數:前一個值、當前值、項的索引和數組對象。這個函數返回的任何值都會作為第一個參數自動傳給下一項。第一次迭代發生在數組的第二項上,因此第一個參數是數組的第一項,第二個參數就是數組的第二項。

下面代碼用reduce()實現數組求和,數組一開始加了一個初始值10。

varvalues = [1,2,3,4,5];

varsum = values.reduceRight(function(prev, cur, index, array){
returnprev + cur;
},10);

總結

以上是生活随笔為你收集整理的js中的数组方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 操操操操网| 五月天婷婷基地 | 久草午夜 | 黄在线免费观看 | 国产女上位 | 美女又爽又黄又免费 | 免费观看视频一区 | 精品国产av 无码一区二区三区 | 中国女人做爰视频 | 免费视频网站www | 岛国色图 | 欧美又大粗又爽又黄大片视频 | 日韩一二三区视频 | 日本人做受免费视频 | 夜色视频网站 | 亚洲欧美中文字幕5发布 | 瑟瑟网站免费 | 制服丝袜第一页在线观看 | 中文字幕有码在线 | 调教丰满的已婚少妇在线观看 | 国产熟女一区二区三区四区 | 欧美日韩成人一区二区在线观看 | 亚洲av片在线观看 | 国内精品国产三级国产aⅴ久 | 黑人巨茎大战欧美白妇 | 国产精品av在线 | 国产深夜福利在线 | 国产精品福利一区二区三区 | 亚洲一区二区三区四区在线播放 | 国产嫩草在线观看 | 美女福利视频一区 | 免费在线日韩av | 欧美一区亚洲 | 操三八男人的天堂 | 理论片大全免费理伦片 | 18禁男女爽爽爽午夜网站免费 | 欧美日韩国产麻豆 | 亚洲精品免费播放 | 国产美女特级嫩嫩嫩bbb | 久久精品电影 | 日韩精品一区二区三区网站 | 成年人黄色免费视频 | 日韩欧美精品一区二区三区 | 欧美成年人视频 | 久啪视频 | 久久精品视频6 | 在线观看视频中文字幕 | 久久公开视频 | 一吻定情2013日剧 | 亚洲精品久久久蜜桃网尤妮丝 | 精品国产aⅴ一区二区三区东京热 | 三上悠亚久久 | 欧美韩国日本一区 | 91国偷自产一区二区三区观看 | 欧美在线高清 | 国产精品福利网站 | 亚日韩欧美 | 99精品国自产在线 | 狂野欧美性猛交xxⅹ李丽珍 | 寡妇激情做爰呻吟 | 少妇无套内谢久久久久 | 日韩一区二区免费看 | 91精品国产免费 | 欧美日本免费 | 久久视频在线 | 日韩久久精品一区二区 | 国语对白做受欧美 | 亚洲国产精品美女 | 国精产品一区一区三区视频 | 日本激情久久 | 老子影院午夜伦不卡大全 | 男女洗澡互摸私密部位视频 | 天天操夜夜拍 | av 日韩 人妻 黑人 综合 无码 | 成人性生交大免费看 | 在线观看va | 欧美激情视频网站 | 亚洲夜夜夜 | 激情啪啪网 | 天天想你在线观看完整版电影免费 | 伊人久久麻豆 | av在线免费网址 | 国产精品jizz在线观看美国 | 精品人妻在线一区二区三区 | 爱情岛论坛亚洲线路一 | 国产欧美色图 | 亚洲成人黄色在线观看 | 一区视频在线 | 久久综合综合 | 日韩区在线观看 | 欧美人与性动交α欧美精品 | 久草高清 | 国产福利免费看 | 亚洲欧美乱日韩乱国产 | 黄色激情毛片 | 韩国精品在线 | 波多野结衣绝顶大高潮 | 久久精品欧美一区二区三区不卡 | 欧美亚洲免费 |