1. 程式人生 > 其它 >三、ES6中陣列拓展

三、ES6中陣列拓展

一、Array.of()

將引數中所有值作為元素形成陣列:

console.log(Array.of(1, 2, 3, 4)); // [1, 2, 3, 4]

引數的值可以為不同的型別:

console.log(Array.of(1, '2', true)); // [1, '2', true]

引數為空時返回空陣列:

console.log(Array.of()); // []

注意:

let arr1 = new Array(10); //是一個長度為10的空陣列
let arr2 = Array.of(10); //長度為1,第一個元素值為10的陣列

二、Array.from()

引數為陣列,返回與原陣列一樣的陣列:

console.log(Array.from([1, 2])); // [1, 2]

引數含空位:

console.log(Array.from([1, , 3])); // [1, undefined, 3]

對陣列元素進行處理,形成新的陣列:

let arr = Array.from([1,2,3],n=>n*2);
console.log(arr); //[2,4,6]

利用函式處理陣列,形成新的陣列(奇數+1,偶數不變的規則):

//方案一:
let arr1 = [1,2,3,4,5,6];
let arr2 = Array.from(arr1,function(n){
	if(n%2==1)
		return n+1;
	else
		return n;
});
console.log(arr2);

//方案二:
function f(n)
{
	if(n%2==1)
		return n+1;
	else
		return n;				
}
let arr1 = [1,2,3,4,5,6];
let arr2 = Array.from(arr1,function(n){
	return f(n);
});
console.log(arr2);

三、類陣列物件轉換

將類似陣列的物件轉換成真正的陣列:

let arr = Array.from({
  0: "jack",
  1: "rose",
  2: "jordan",
  length: 3
});
console.log(arr); // ["jack", "rose", "jordan"]

沒有 length 屬性,則返回空陣列:

let arr = Array.from({
  0: "jack",
  1: "rose",
  2: "jordan",
});
console.log(arr); // []	

元素屬性名不為數值且無法轉換為數值,返回長度為length元素值為undefined的陣列:

let arr = Array.from({
	a: "jack",
	b: "rose",
	c: "jordan",
	length: 3
});
console.log(arr); // [undefined, undefined,undefined]

四、轉換可迭代物件

轉換map:

let map = new Map();
map.set('23', '喬丹');
map.set('33', '皮蓬');
map.set('99', '羅德曼');
console.log(Array.from(map)); //[['23','喬丹'],['33','皮蓬'],['99','羅德曼']]

轉換set:

let set = new Set();
set.add("喬丹");
set.add("皮蓬");
set.add("羅德曼");
console.log(Array.from(set)); //["喬丹","皮蓬","羅德曼"]

轉換字串:

let str = "hello!";
console.log(Array.from(str)); //['h','e','l','l','o','!']

五、擴充套件運算子...

複製陣列內容:

//方案一:複製陣列內容
// let arr1 = [1,2,3,4];
// let arr2 = [...arr1];
// console.log(arr2);
// console.log(arr1 === arr2); //false(arr1和arr2引用不同,只是值相同)

//方案二:直接陣列名賦值
// let arr1 = [1,2,3,4];
// let arr2 = arr1;
// console.log(arr2);
// console.log(arr1 === arr2); //true(arr1和arr2的引用相同)

合併陣列:

let arr1 = [1,2,3,4];
let arr2 = [1,2,3,4];
let arr = [...arr1,...arr2];
console.log(arr);

作為函式引數(可以接受可變長度的引數):

function Add(...items)
{
	let sum = 0;
	for(let item of items)
	{
		sum += item;
	}
	return sum;
}
let result1 = Add(1,2,3);
let result2 = Add(1,3,5,7,9);
console.log(result1);
console.log(result2);

六、擴充套件方法

查詢:

//查詢find()和findIndex()
//find():查詢陣列中符合條件的元素,若有多個符合條件的元素,則返回第一個元素。
// let arr = ["喬丹","皮蓬","羅德曼"];
// let r = arr.find(item=>item == "皮蓬");
// console.log(r);   //皮蓬

// let arr = ["喬丹","皮蓬","羅德曼"];
// let r = arr.find(item=>item == "姚明");
// console.log(r);   //undefined		

// let arr = [1,2,3,4];
// console.log(arr.find(item => item > 2)); // 3

//findIndex():查詢陣列中符合條件的元素索引,若有多個符合條件的元素,則返回第一個元素索引。
let arr = [10,20,30,40];
console.log(arr.findIndex(item => item > 10)); // 1

填充:

//fill():將一定範圍索引的陣列元素內容填充為單個指定的值。
// 引數1:用來填充的值
// 引數2:被填充的起始索引
// 引數3(可選):被填充的結束索引,預設為陣列末尾
// let arr = [1,2,3,4];
// arr.fill(0,1,2);
// console.log(arr);

//copyWithin():將一定範圍索引的陣列元素修改為此陣列另一指定範圍索引的元素。
// 引數1:被修改的起始索引
// 引數2:被用來覆蓋的資料的起始索引
// 引數3(可選):被用來覆蓋的資料的結束索引,預設為陣列末尾
// let arr = [1,2,3,4];
// arr.copyWithin(0,2,4);
// console.log(arr); // [3, 4, 3, 4]

// let arr = [1, 2, ,4];
// arr.copyWithin(0, 2, 4);
// console.log(arr); // [, 4, , 4]

//第一個引數為負數表示倒數
// let arr = [1,2,3,4];
// arr.copyWithin(-2,0);
// console.log(arr); // [1, 2, 1, 2]

包含:

//includes():陣列是否包含指定值。
// 引數1:包含的指定值
// let arr = [1,2,3];
// let r = arr.includes(1);    // true
// console.log(r);

// 引數2:可選,搜尋的起始索引,預設為0
let arr = [1,2,3];
let r = arr.includes(1, 1); // false
console.log(r);

巢狀陣列轉一維陣列:

console.log([1 ,[2, 3]].flat()); // [1, 2, 3]

// 指定轉換的巢狀層數
console.log([1, [2, [3, [4, 5]]]].flat(2)); // [1, 2, 3, [4, 5]]

// 不管巢狀多少層
console.log([1, [2, [3, [4, 5]]]].flat(Infinity)); // [1, 2, 3, 4, 5]

// 自動跳過空位
console.log([1, [2, , 3]].flat());<p> // [1, 2, 3]

本文來自部落格園,作者:農碼一生,轉載請註明原文連結:https://www.cnblogs.com/wml-it/p/15967779.html


技術的發展日新月異,隨著時間推移,無法保證本部落格所有內容的正確性。如有誤導,請大家見諒,歡迎評論區指正!
個人開原始碼連結,歡迎點亮:
GitHub:https://github.com/ITMingliang
Gitee:https://gitee.com/mingliang_it
GitLab:https://gitlab.com/ITMingliang
進開發學習交流群: