js中的Array
js中的Array
啥是ArrayLike对象
类似,下面这种对象的就是ArrayLike
var arraylike = {
0: "a",
1: "b",
2: "c",
length: 3
}
arraylike.forEach(element => { // 报错
console.log(element);
});
ArrayLike对象和数组类似,但是不能使用数组的方法,因为它是继承自Object.prototype而不是Array.prototype 获取dom元素的方法,一般都会产生ArrayLike对象
将ArrayLike对象转换成Array
方式一:
var array = Array.from(arraylike); 方式二:
var array = Array.from(arraylike, item => item+item);
reduce方法
reduce方法其实类似于叠罗汉,取数组中第一个参数和第二个参数做运算,然后将结果返回,作为下一次运算的第一个元素与数组中的第三个元素运算,重复这种操作
var array = [1,2,3,4,5];
var res = array.reduce((a, b) => a + b); // 15 求和运算
var res = array.reduce((a, b) => a + b, 10); // 25 传递第二个参数作为运算的起始第一个参数 数组格式化成对象,这对于处理后端api数据,方便前端渲染很有用
var array = [
{name: "小明", age: "10"},
{name: "小张", age: "20"},
{name: "小王", age: "30"},
] 方式一:
var obj = array.reduce((a, b) => {
a[b.name] = b.age;
return a;
}, {}); // { '小明': '10', '小张': '20', '小王': '30' } 方式二:
var obj = array.reduce((a, b) => Object.assign(a, {
[b.name]: b.age
}), {}); 方式三:
var obj = array.reduce((a, b) => ({...a, [b.name]: b.age}), {});
map方法
map方法循环便利所有元素,产生一个新的数组 var arr = [1,2,3,4,5];
var res = arr.map(item => item+1); // [ 2, 3, 4, 5, 6 ] var res = arr.map(function(item){
return item+this.init;
}, {
init: 1
}); // [ 2, 3, 4, 5, 6 ]
filter方法
filter方法循环便利所有元素,根据条件筛选出符合的元素,产生一个新的数组
var arr = [1,2,3,4,5];
var res = arr.filter(item => item > 3) // [ 4, 5 ]
sort方法
sort方法在原数组的基础上进行排序
按照字母表顺序排序
var arr = ["c", "b", "f", 1, "g", 2];
arr.sort((a, b) => a.toString().localeCompare(b)); // [ 1, 2, 'b', 'c', 'f', 'g' ] 升序排序
var arr = [3,5,2,1,9];
arr.sort((a, b) => a - b);
for...of
遍历数组
var arr = [3,5,2,1,9];
for(let item of arr) {
console.log(item);
}
every
有条件的暂停遍历
var arr = [3,5,2,"end",1,9];
arr.every(item => {
console.log(item);
return item != "end";
})
some
和上面的every逻辑上正好相反
var arr = [3,5,2,"end",1,9];
arr.some(item => {
console.log(item);
return item === "end";
})
find和findIndex
var arr = [
{name: "小明", age: "10"},
{name: "小张", age: "20"},
{name: "小王", age: "30"},
]; var res = arr.find(item => item.age==20); // { name: '小张', age: '20' }
var res = arr.findIndex(item => item.age==20); // 1
解构
var arr = [1,2,3,4,5];
var [a,,b, ...c] = arr;
console.log(a, b, c); // 1 3 [ 4, 5 ]
去重
var arr = [1,1,2,1,1,2,3,3]; 利用reduce进行数组去重
var res = arr.reduce((a,b) => {
if(a.indexOf(b) === -1) {
a.push(b);
}
return a;
}, []) // [ 1, 2, 3 ] 利用filter进行去重
var res = arr.filter((a,b,c) => {
return c.indexOf(a) === b;
}) 利用Set去重
var res = [...new Set(arr)];
js中的Array的更多相关文章
- js中数组Array的一些常用方法总结
var list = new Array()是我们在js中常常写到的代码,今天就总结一下Array的对象具有哪些方法. list[0] = 0; list[1] = 1; list[2] = 2; 或 ...
- JS中数组Array的用法{转载}
js数组元素的添加和删除一直比较迷惑,今天终于找到详细说明的资料了,先给个我测试的代码^-^var arr = new Array();arr[0] = "aaa";arr[1] ...
- JS中数组Array的用法示例介绍 (转)
new Array() new Array(len) new Array([item0,[item1,[item2,...]]] 使用数组对象的方法: var objArray=new Array() ...
- JS中数组Array的用法
js数组元素的添加和删除一直比较迷惑,今天终于找到详细说明的资料了. var arr = new Array(); // 初始化数组arr[0] = "aaa";arr[1] = ...
- D3.js中对array的使用
由于D3类库和array密切相关,我们有必要讨论一下D3中的数据绑定以及在数组内部运算的方法. 1.D3中的数组 和其他编程语言一样,D3的数组元素可以是数字或者字符等类型,例如: someData= ...
- js中关于array的常用方法
最近总结了一些关于array中的常用方法, 其中大部分的方法来自于<JavaScript框架设计>这本书, 如果有更好的方法,或者有关于string的别的常用的方法,希望大家不吝赐教. 第 ...
- JS中部分 Array 对象方法介绍
1.concat() concat() 方法用于连接两个或多个数组.该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本 <script type="text/javascrip ...
- js中数组Array 详解
unshift:将参数添加到原数组开头,并返回数组的长度 pop:删除原数组最后一项,并返回删除元素的值:如果数组为空则返回undefined push:将参数添加到原数组末尾,并返回数组 ...
- js中的Array数组清空
var data = new Array();//数组 data.length = 0;//数组的长度等于0,数组的项就会被清空
随机推荐
- 《The Cg Tutorial》阅读笔记——环境贴图 Environment Mapping
本文为大便一箩筐的原创内容,转载请注明出处,谢谢:http://www.cnblogs.com/dbylk/p/4969956.html 环境贴图 Environment Mapping 一.简介 环 ...
- python基础8之类的实例化过程剖析
一.概述 之前我们说关于python中的类,都一脸懵逼,都想说,类这么牛逼到底是什么,什么才是类?下面我们就来讲讲,什么是类?它具有哪些特性. 二.类的语法 2.1 语法 class dog(obje ...
- poj1469
题解: 二分图匹配 然后判断最大匹配是否是m 代码: #include<cstdio> #include<cmath> #include<algorithm> #i ...
- 深入Guerrilla Games解密次世代开山大作《杀戮地带暗影坠落》(The technology of Killzone Shadow Fall)
文章摘要:这几天终于有时间,把全文翻译完了,自己感觉不是太满意,不过大家能看懂就好,就当一个学习的机会.整篇文章通过SONY第一方游戏工作室Guerrilla Games主创的语录,为我们展现了次世代 ...
- ng 双向数据绑定
1.方向1:model->View模型数据绑定到视图 绑定的方式:①双花括号 ②常见的ng指令(ngRepeat ngIf ngShow....) 效果:数据一旦绑定到视图上,随着数据的修改,视 ...
- python学习之控制语句
#if statement number=int(input("please input a number")); if number<10 : print("is ...
- 【django】Bootstrap 安装和使用
官网 下载:推荐下载源码包 安装Bower:使用Bower安装并管理 Bootstrap 的Less.CSS.JavaScript和字体文件(通过npm安装bower) npm install -g ...
- python笔记-5(内置函数)
一.内置函数 1.abs()--取绝对值函数 print(abs(-0.11)) x=-0.01 y=0.11 print(abs(x),abs(y)) ----------------------- ...
- ajax传递数组后台接收不到值的问题
背景: JQGrid需要进行批量删除操作传给后台的是数组,结果后台接收不到值. 后台语言:java 原因: ajax传递参数时,traditional 默认为false,JQuery会深度序列化参数对 ...
- 转载 eclipse中的include设置
备注:在10.1版的niosii使用的eclipse中设置的方法是右键->properties->c/c++general->path and symbols->include ...