網(wǎng)站首頁 編程語言 正文
一、Array.of()
將參數(shù)中所有值作為元素形成數(shù)組:
console.log(Array.of(1, 2, 3, 4)); // [1, 2, 3, 4]
參數(shù)的值可以為不同的類型:
console.log(Array.of(1, '2', true)); // [1, '2', true]
參數(shù)為空時返回空數(shù)組:
console.log(Array.of()); // []
注意:
let arr1 = new Array(10); //是一個長度為10的空數(shù)組
let arr2 = Array.of(10); //長度為1,第一個元素值為10的數(shù)組
二、Array.from()
參數(shù)為數(shù)組,返回與原數(shù)組一樣的數(shù)組:
console.log(Array.from([1, 2])); // [1, 2]
參數(shù)含空位:
console.log(Array.from([1, , 3])); // [1, undefined, 3]
對數(shù)組元素進(jìn)行處理,形成新的數(shù)組:
let arr = Array.from([1,2,3],n=>n*2);
console.log(arr); //[2,4,6]
利用函數(shù)處理數(shù)組,形成新的數(shù)組(奇數(shù)+1,偶數(shù)不變的規(guī)則):
//方案一:
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);
三、類數(shù)組對象轉(zhuǎn)換
將類似數(shù)組的對象轉(zhuǎn)換成真正的數(shù)組:
let arr = Array.from({
0: "jack",
1: "rose",
2: "jordan",
length: 3
});
console.log(arr); // ["jack", "rose", "jordan"]
沒有 length 屬性,則返回空數(shù)組:
let arr = Array.from({
0: "jack",
1: "rose",
2: "jordan",
});
console.log(arr); // []
元素屬性名不為數(shù)值且無法轉(zhuǎn)換為數(shù)值,返回長度為length元素值為undefined的數(shù)組:
let arr = Array.from({
a: "jack",
b: "rose",
c: "jordan",
length: 3
});
console.log(arr); // [undefined, undefined,undefined]
四、轉(zhuǎn)換可迭代對象
轉(zhuǎn)換map:
let map = new Map();
map.set('23', '喬丹');
map.set('33', '皮蓬');
map.set('99', '羅德曼');
console.log(Array.from(map)); //[['23','喬丹'],['33','皮蓬'],['99','羅德曼']]
轉(zhuǎn)換set:
let set = new Set();
set.add("喬丹");
set.add("皮蓬");
set.add("羅德曼");
console.log(Array.from(set)); //["喬丹","皮蓬","羅德曼"]
轉(zhuǎn)換字符串:
let str = "hello!";
console.log(Array.from(str)); //['h','e','l','l','o','!']
五、擴(kuò)展運算符...
復(fù)制數(shù)組內(nèi)容:
//方案一:復(fù)制數(shù)組內(nèi)容
// let arr1 = [1,2,3,4];
// let arr2 = [...arr1];
// console.log(arr2);
// console.log(arr1 === arr2); //false(arr1和arr2引用不同,只是值相同)
//方案二:直接數(shù)組名賦值
// let arr1 = [1,2,3,4];
// let arr2 = arr1;
// console.log(arr2);
// console.log(arr1 === arr2); //true(arr1和arr2的引用相同)
合并數(shù)組:
let arr1 = [1,2,3,4];
let arr2 = [1,2,3,4];
let arr = [...arr1,...arr2];
console.log(arr);
作為函數(shù)參數(shù)(可以接受可變長度的參數(shù)):
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);
六、擴(kuò)展方法
查找:
//查找find()和findIndex()
//find():查找數(shù)組中符合條件的元素,若有多個符合條件的元素,則返回第一個元素。
// 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():查找數(shù)組中符合條件的元素索引,若有多個符合條件的元素,則返回第一個元素索引。
let arr = [10,20,30,40];
console.log(arr.findIndex(item => item > 10)); // 1
填充:
//fill():將一定范圍索引的數(shù)組元素內(nèi)容填充為單個指定的值。
// 參數(shù)1:用來填充的值
// 參數(shù)2:被填充的起始索引
// 參數(shù)3(可選):被填充的結(jié)束索引,默認(rèn)為數(shù)組末尾
// let arr = [1,2,3,4];
// arr.fill(0,1,2);
// console.log(arr);
//copyWithin():將一定范圍索引的數(shù)組元素修改為此數(shù)組另一指定范圍索引的元素。
// 參數(shù)1:被修改的起始索引
// 參數(shù)2:被用來覆蓋的數(shù)據(jù)的起始索引
// 參數(shù)3(可選):被用來覆蓋的數(shù)據(jù)的結(jié)束索引,默認(rèn)為數(shù)組末尾
// 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]
//第一個參數(shù)為負(fù)數(shù)表示倒數(shù)
// let arr = [1,2,3,4];
// arr.copyWithin(-2,0);
// console.log(arr); // [1, 2, 1, 2]
包含:
//includes():數(shù)組是否包含指定值。
// 參數(shù)1:包含的指定值
// let arr = [1,2,3];
// let r = arr.includes(1); // true
// console.log(r);
// 參數(shù)2:可選,搜索的起始索引,默認(rèn)為0
let arr = [1,2,3];
let r = arr.includes(1, 1); // false
console.log(r);
嵌套數(shù)組轉(zhuǎn)一維數(shù)組:
console.log([1 ,[2, 3]].flat()); // [1, 2, 3]
// 指定轉(zhuǎn)換的嵌套層數(shù)
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
相關(guān)推薦
- 2022-07-27 詳解Python中Addict模塊的使用方法_python
- 2022-07-18 Nio中Buffer的Scattering和Gathering
- 2022-10-29 正則表達(dá)式從HTML中匹配img標(biāo)簽的圖片地址_正則表達(dá)式
- 2022-07-09 C語言堆與二叉樹的順序結(jié)構(gòu)與實現(xiàn)_C 語言
- 2022-04-10 MalformedByteSequenceException: 1字節(jié)的 UTF-8 序列的字節(jié) 1
- 2022-05-24 Django框架cookie和session方法及參數(shù)設(shè)置_python
- 2022-08-30 C++超詳細(xì)介紹模板_C 語言
- 2022-02-20 C#?.NET實現(xiàn)掃描識別圖片中的文字_C#教程
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支