ES6扩展——数组的新方法(Array.from、Array.of、Array.fill、Array.includes、keys values entries 、find)
1、Array.from(objec,回调函数)将一个ArrayLike对象或者Iterable对象(类数组对象)转换成一个数组
1)该类数组对象必须具有length属性,用于指定数组的长度。如果没有length属性,那么转换后的数组是一个空数组
2)该类数组对象的属性名必须为数值型或字符串型的数字
//新的方法
//Array.from可以把一个类数组的对象转成数组
//该类数组对象的属性名必须为数值型或字符串型的数字
const obj = {
0:1,
1:22,
2:false,
length:2 //false不在数组中是因为length为2
};
//from()方法的作用是将一个ArrayLike对象或者Iterable对象转换成一个Array
//还可以接收第二个参数,是一个回调函数
console.log(Array.from(obj, item => item * 2)); //[2,44]
//其他将类数组转换成数组的方法(相对from方法少了第二个参数):
Array.prototype.slice.call();
[].slice.call();
[...]
2、Array.of()将传入的参数合并为一个数组
//Array.of把传进去的参数合成一个数组
console.log(Array.of(1,2,'123',false)); //[1,2,'123',false]
3、Array().fill(num,start,end)填充数组并且指定范围
//Array().fill(num,start,end)填充数组并且指定范围,不包括end脚标
//可以很方便的去指定一个数组的默认值
let arr = new Array(5); //[empty * 5]
let arr1 = new Array(5).fill(0); //[0,0,0,0,0]
//如果数组原先有值,fill会覆盖掉
console.log([1,2,3].fill(0)); //[0,0,0]
//指定范围
let arr3 = new Array(5).fill(0,0,3); //[0,0,0,empty*2]
//new Array()这个构造函数会根据参数进行重载,只有一个参数的时候就是表示数组的长度,有多个参数就会作为数组的成员
4、Array.includes()返回布尔值,用来判断数组中是否存在某一项
//Array.includes()返回布尔值,用来判断数组中是否存在某一项
var arr = [1,2,3,4];
console.log(arr.includes(1)); //true
console.log(arr.includes(55)); //false
5、keys values entries
//keys可以拿到数组中的每一个下标
const arr = [1,2,3,444];
console.log(arr.keys()); //Array Iterator{} 迭代器接口
for(let i of arr.keys()){
console.log(i); //四行的值分别是:0 1 2 3
}
//values可以拿到数组中的每一项
for(let v of arr.values()){
console.log(v); //四行的值分别是:1 2 3 444
}
//entries可以同时拿到下标和对应的值,返回的是数组
for(let u of arr.entries()){
console.log(u); //四个数组:[0,1] [1,2] [2,3] [3,444]
}
//可以解构赋值,同时拿到下标跟值
for(let [i,v] of arr.entries()){
console.log(i,v); //四行的值分别是:0 1 1 2 2 3 3 444
}
6、find方法根据条件(回调)按顺序遍历数组,当回调返回true时,就返回当前遍历到的值。这个方法用的比较多
//find 根据条件(回调)按顺序遍历数组,当回调返回true时,就返回当前遍历到的值
const res = [1,7,6,3].find(function(value,index,arr){
console.log('value:',value);
console.log('index:',index);
console.log('arr',arr);
return value % 2 === 0;
});
console.log(res); //6 //也可以写成箭头函数
const res1 = [1,7,6,3].find((value,index,arr) => value % 2 === 0 );
console.log(res1); //6
7、findIndex根据条件(回调)按顺序遍历数组,当回调返回true时,就返回当前遍历到的下标。这个方法用的比较多
//findIndex 根据条件(回调)按顺序遍历数组,当回调返回true时,就返回当前遍历到的下标
const res2 = [1,7,6,3].findIndex((value,index,arr) => value % 2 ===0 );
console.log(res2); //返回数值6的脚标:2
//findIndex跟indexOf相似,只是indexOf无法判断有没有NaN,但是findIndex可以判断
const res3 = [1,7,6,3,NaN].findIndex((value,inde,arr) =>
Number.isNaN(value));
console.log(res3); //4
ES6扩展——数组的新方法(Array.from、Array.of、Array.fill、Array.includes、keys values entries 、find)的更多相关文章
- ES6中数组的新方法
数组的扩展 1.1扩展运算符 1.1.1:... 扩展运算符(spread)是三个点(...).它好比 rest 参数的逆运算,将一个数组转为用逗号分隔的参数序列. <body> < ...
- 数组的新方法 forEach some filter findIndex
forEach some filter findIndex这些都属于数组的新方法,都会对数组中的每一项,进行遍历,执行相关的操作: 只不过在循环的时候有些不一样 参考资料:https://wan ...
- vue学习(十四) 条件搜索框动态查询表中数据 数组的新方法
//html <div id="app"> <label> 名称搜索关键字: <input type="text" clasa=& ...
- ES6中数组新增的方法-超级好用
Array.find((item,indexArr,arr)=>{}) 掌握 找出第一个符合条件的数组成员. 它的参数是一个回调函数,对所有数组成员依次执行该回调函数. 直到找出第一个返回值为t ...
- Vue中遍历数组的新方法
1.foreach foreach循环对不能使用return来停止循环 search(keyword){ var newList = [] this.urls.forEach(item =>{ ...
- es5数组的新方法
1.every方法 //逻辑判断返回值为一个Boolean值 every方法就是每一个返回函数的返回值都是true的时候,才为true,否则为false var arr=[1,2,5,88,5,555 ...
- 转 JavaScript里的数组转化新方法Array.From
过去,我们使用各种各样的方法来将类似Array对象的东西(比如 arguments 和 NodeList) 转换成真的数值.比如下面这个: 将NodeList转换成数组 基本上,这些东西我们都可以使用 ...
- ES6扩展——字符串部分新的方法
1.padStart padEnd(count, 字符串) 补全字符串 //padStart(num,str) padEnd补全一个字符串的长度 //num表示补全到几位,str是用来填充的字符串 { ...
- ES6扩展——数组扩展
1.结合扩展运算符使用.通过扩展运算符,在调用函数的时候,把一个数组展开,然后作为这个函数的参数 //结合扩展运算符使用 function foo(a,b,c){ console.log(a); // ...
随机推荐
- vue-cli 3.0脚手架创建vue项目
1. 卸载vue-cli 2.0 npm uninstall -g vue-cli 2. 安装vue-cli 3.0 npm install @vue/cli 3. 创建项目 npm create & ...
- 第七篇 -- 添加CSV Data Set Config
参考链接:https://blog.csdn.net/vv19910825/article/details/82773220 先来看看我们开启的接口 @RequestMapping(value = & ...
- etcd学习(5)-etcd的Raft一致性算法原理
ETCD的Raft一致性算法原理 前言 Raft原理了解 raft选举 raft中的几种状态 任期 leader选举 日志复制 安全性 leader宕机,新的leader未同步前任committed的 ...
- 为什么大家都在用WebRTC?
WebRTC代表网络实时通信.它是一种非常令人兴奋,强大且具有高度破坏性的尖端技术和标准.自从WebRTC诞生以来,80%的浏览器都开始支持它.有数据显示,2017年~2021年期间,WebRTC市场 ...
- 必备!一文掌握Wordpress插件
必备!一文掌握Wordpress插件 什么是插件? Wordpress是一个非常强大的建站系统,而在我们建站的过程中,插件的使用必不可少. 插件是WordPress功能的扩展,也是WordPress得 ...
- RHCE_DAY06
iptables防火墙 ----匹配及停止 nerfilter/iptables:工作在主机或网络的边缘,对于进出本主机或网络的报文根据事先定义好的检查规则作匹配检测,对于能够被规则所匹配到的报文做出 ...
- 40k*16 薪,五年Android开发4轮面试拿下腾讯 Offer !(附真题)
概述 感觉毕业后时间过得真快啊,从16年6月本科毕业入职了一家不大的公司,到现在快五年了,前段时间金三银四想着找一个新的工作,前前后后花了一个多月的时间复习以及面试,前几天拿到了腾讯的offer,想把 ...
- 《高性能利器》-32张图带你解决RocketMQ所有场景问题
一.RocketMQ的基本原理 RocketMQ基本架构图如下 从这个架构图上我们可以知道,RocketMQ有4块核心部分: NameServer:管理Broker的信息,让使用MQ的系统感知到集群里 ...
- SpringMVC学习03(控制器Controller)
3.控制器Controller 3.1 控制器Controller 控制器复杂提供访问应用程序的行为,通常通过接口定义或注解定义两种方法实现. 控制器负责解析用户的请求并将其转换为一个模型. 在Spr ...
- AI+云原生,把卫星遥感虐的死去活来
摘要:遥感影像,作为地球自拍照,能够从更广阔的视角,为人们提供更多维度的辅助信息,来帮助人类感知自然资源.农林水利.交通灾害等多领域信息. 本文分享自华为云社区<AI+云原生,把卫星遥感虐的死去 ...