es6 的数组的方法
es6 数组的拓展
数组的类 Array
数组的定义:
1. var arr=[];
2. var arr=new Array(3) // 3 代表有三个元素
arr[0]=12;
arr[1]=24;
arr[2]=36;
3. var arr=new Array("zhang","lisi","wang");
[] 代表空数组 [empty] 代表一个空元素
var arr=new Array("4");
代表有一个元素 为 4
var arr=new Array(3) 与 var arr=new Array("3") 的区别?
第一个的 3 代表,这个数组中有 3 个元素, 第二个的 3 代表,这个数组中有一个元素,为3
数组的方法:
1. of() 他是 Array 类上的方法
var arr=Array.of(4);
console.log(arr) // [4] 返回一个数组,里面有一个元素为 4
2. forEach() 他是原型的方法,用于对数组的遍历,返回值 undefined
案例:
var arr=[12,23,56,96,105];
var as = arr.forEach((item,index)=>{
// item 代表元素 index 代表索引
console.log(item)
console.log(index)
})
console.log(as) // undefined
3. map 原型上的方法,用于数组遍历加工, 返回值:仍然是个新数组, 参数:回调函数
var arr=[12,36,85,96,102];
var as = arr.map((item,index)=>{
return item+3; // 此方法一定要 return
})
4. filter 过滤 从数组中找出所有的指定条件的元素,并返回成一个新的数组,不改变原有数组 return 返回值是 true 就保留,返回值是 false 就不保留
var arr=[
{name:"zhang",age:20},
{name:"lisi",age:10}
];
var as=arr.filter((item,index)=>{
// item 元素 index 索引
return item.age>15; // 条件语句的返回值 true 和 false
})
console.log(as) // 返回满足条件的 {name:"zhang",age:20};
5. find:查找,查找第一个满足条件的元素 参数:回调函数 返回值:第一个满足条件的元素
var arr=[
{name:"zhang",age:20},
{name:"lisi",age:30},
{name:"wang",age:15}
]
var as=arr.find((item,index)=>{
// item 元素 index 索引
return item.age>18;
})
console.log(as) // 他的返回结果就只有一个,(对数组中逐个查找,当返回值为 true,说明找到,直接将结果返回,不在继续查找)
6. every:看数组中的每个是元素是否都满足条件 参数:回调函数 返回值:布尔
var arr=[
{name:"zhang",age:20},
{name:"lisi",age:10}
]
var as=arr.every((item,index)=>{
// item 元素 index 索引
return item.age>5;
})
console.log(as) // true 这种结果返回的 true,因为它的所有元素都满足这个条件,但是只要有一个不满足,返回值为 false
7. some: 看数组中的元素是否都满足条件,只要有一个满足,返回值是 true ,全部都不满足这个条件,返回值为false 参数:回调函数
var arr=[
{name:"zhang",age:20},
{name:"lisi",age:10}
]
var as=arr.some((item,index)=>{
// item 元素 index 索引
return item.age>30;
})
console.log(as) // false 所有的元素都不满足他的条件,返回 false,但只要有一个满足,返回 true
8. reduce:迭代,在原有的基础上继续
var arr=[1,2,3,4,5,6,7,8,9,10];
var as=arr.requce((prev,item,index)=>{
// prev 代表上一个的返回值(return 的返回值,就好比 item = 3 的时候,prev 代表上次返回的结果,return 1+2)
// item 数组的元素,如果遍历的话,默认从第二个元素开始, index 数组的索引
return prev+item // return 的结果
},0) // 这个0 代表第一个返回的结果,最终目的是让 item 从第一个元素开始
上面的代码翻译为 var as=1+2+3+4+5+6+7+8+9+10
console.log(as) // 55
注意:
1. 默认从第二个元素开始执行,第一个元素没有上一个
2. 第一次执行返回的是第一个元素,reduce 的参数 是一个回调函数,回调函数中有三个参数,第一个叫 prev 代表上一次 reduce 执行的返回值就,第二个叫 item 代表返回的元素
第三个叫 index 返回的是当前的索引
3. 如果想让 reduce 从第一个元素开始执行,(默认从第二个),回调函数后面的参数,就是第一次执行的 prev
1. 面试题
将一个数组转换成对象,属性是数组的元素,属性值是元素的个数
解答;
es6 的数组的方法的更多相关文章
- ES6之数组扩展方法【一】(相当好用)
form 转化为真正的数组 先说一下使用场景,在Js中,我们要经常操作DOM,比如获取全部页面的input标签,并且找到类型为button的元素,然后给这个按钮注册一个点击事件,我们可能会这样操作: ...
- es6 filter() 数组过滤方法总结
1.创建一个数组,判断数组中是否存在某个值 var newarr = [ { num: , val: 'ceshi', flag: 'aa' }, { num: , val: 'ceshi2', fl ...
- es6 filter() 数组过滤方法总结(转载)
1.创建一个数组,判断数组中是否存在某个值 var newarr = [ { num: 1, val: 'ceshi', flag: 'aa' }, { num: 2, val: 'ceshi2', ...
- 关于ES6的数组字符串方法
注:ES6的一些新属性会显示语法错误,不过不会影响效果,在Languages里面也可以调: let:用来定义变量 特点:只能在代码块里面使用,let拥有块级作用域;并且let不允许重复声明;比如: v ...
- es6数组的方法
1.复习的函数 函数是由关键字function声明的,他是一个引用数据类型,是Function的实例,在调用的时候会开辟一个私有空间 2.函数的成员 arguments:null (是实参构成的数组 ...
- ES6使用的一些方法
查找数组中符合条件的所有记录 var list=[ {id:1,name:"张三"}, {id:2,name:"李四"}, {id:3,name:"王 ...
- 前端面试之JavaScript中数组的方法!【残缺版!!】
前端面试之JavaScript中数组常用的方法 7 join Array.join()方法将数组中所有元素都转化为字符串并连接在-起,返回最后生成的字 符串.可以指定一个可选的字符串在生成的字符串中来 ...
- 关于ES3、ES5、ES6以及ES7所有数组的方法(api)的总结
起因:工作用经常用到操作数组的方法,这里进行一下总结,我尽量以简洁的语言概括每个方法(api)的作用.如果您想快速定位,可以Control+F 然后搜相应的方法即可定位 :) ES3的数组方法 joi ...
- ES6中数组的新方法
数组的扩展 1.1扩展运算符 1.1.1:... 扩展运算符(spread)是三个点(...).它好比 rest 参数的逆运算,将一个数组转为用逗号分隔的参数序列. <body> < ...
随机推荐
- luogu P5504 [JSOI2011]柠檬
bgm(雾) luogu 首先是那个区间的价值比较奇怪,如果推导后可以发现只有左右端点元素都是同一种\(s_x\)的区间才有可能贡献答案,并且价值为\(s_x(cnt(x)_r-cnt(x)_{l-1 ...
- Vue中,过滤器的使用方法!
Vue.js允许自定义过滤器,可被用于一些常见的文本格式化.过滤器可以用在两个地方:双花括号插值和v-bind表达式.过滤器应该被添加在JavaScript表达式的尾部,由“管道”符号指示:(借官方的 ...
- 谷歌浏览器(Chrome)离线包的下载方法!
谷歌浏览器(Chrome)其实可以下载离线包,用离线包安装的好处,就是一次获得全部安装文件,不需要漫长的在线下载过程了! 下载地址:https://www.google.com/chrome/eula ...
- js带有遮罩的弹窗
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- c++ 递归算法实现排列组合
通过引用的方式来传值,具体的实现的方法如下 void pc(int m,int n,int &position,int (&a)[100]) { //如果运算得到那个数 if (pos ...
- 【基础操作】博弈论 / SG 函数详解
博弈死我了……(话说哪个小学生会玩博弈论提到的这类弱智游戏,还取石子) 先推荐两个文章链接:浅谈算法——博弈论(从零开始的博弈论) 博弈论相关知识及其应用 This article was updat ...
- UVA - 11107 Life Forms (广义后缀自动机+后缀树/后缀数组+尺取)
题意:给你n个字符串,求出在超过一半的字符串中出现的所有子串中最长的子串,按字典序输出. 这道题算是我的一个黑历史了吧,以前我的做法是对这n个字符串建广义后缀自动机,然后在自动机上dfs,交上去AC了 ...
- linux yum的配置文件 repo文件详解
linux yum的配置文件 repo文件详解 什么是repo文件?repo文件是Fedora中yum源(软件仓库)的配置文件,通常一个repo文件定义了一个或者多个软件仓库的细节内容,例如我们将从哪 ...
- static成员变量
可以创建一个由同一个类的所有对象共享的成员变量.要创建这样的成员,只需将关键字 static 放在变量声明的前面,如下面的类所示: class StatDemo { private: static i ...
- Spring整合MongoDB(转)
1.认识Spring Data MongoDB 之前还的确不知道Spring连集成Nosql的东西都实现了,还以为自己又要手动封装一个操作MongoDB的API呢,结果就发现了Spring Data ...