Javascritp Array数组方法总结
合并数组 - concat()
用法一 (合并两个数组)
var hege = ["Cecilie", "Lone"];
var stale = ["Emil", "Tobias", "Linus"];
var children = hege.concat(stale);
console.log(children ); // ["Cecilie", "Lone", "Emil", "Tobias", "Linus"]
用法二 (合并多个数组)
var parents = ["Jani", "Tove"];
var brothers = ["Stale", "Kai Jim", "Borge"];
var children = ["Cecilie", "Lone"];
var family = parents.concat(brothers, children);
console.log(family); // ["Jani", "Tove", "Stale", "Kai Jim", "Borge", "Cecilie", "Lone"]
数组转字符串 - join()、toString()
两种方法都返回新的字符串
join() 方法
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var a = fruits.join();
console.log(a); // "Banana,Orange,Apple,Mango"
toString() 方法
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var a = fruits.toString();
console.log(a); // "Banana,Orange,Apple,Mango"
相同点:
都可以将数组转字符串。
区别:
join还有另外的用法:join() 可接受一个参数作为元素之间的连接符号
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var a = fruits.join("-");
console.log(a); // "Banana-Orange-Apple-Mango"
删除数组最后一个元素 - pop()
pop 返回元素的最后一个元素,原数组最后一个删除。
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var a = fruits.pop();
console.log(a); // "Mango"
console.log(fruits ); // ["Banana", "Orange", "Apple"]
添加元素 - push()
push 返回的是数组的长度,原数组最后面添加一个新元素
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var a = fruits.push("Kiwi");
console.log(a); // 5
console.log(fruits); // ["Banana", "Orange", "Apple", "Mango", "Kiwi"]
数组反转 - reverse()
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.reverse();
console.log(fruits); // ["Mango", "Apple", "Orange", "Banana"]
删除数组第一个元素 - shift()
shift 返回数组的第一个元素,原数组第一个元素被删除
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var a= fruits.shift();
console.log(a); // "Banana"
consoel.log(fruits); // ["Orange", "Apple", "Mango"]
截取数组元素 - slice(start,end)
slice 返回截取的元素组成的数组,原数组不会发生变化。
slice接受两个参数,起始位置和结束位置,第一个参数起始位置如果为负数,表示从数组尾部开始算,如 -1 代表最后一个。如果不传入结束位置,表示从起始位置起到数组结尾的所有元素。
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var a= fruits.slice(1,3);
console.log(a); // ["Orange", "Lemon"]
console.log(fruits); // ["Banana", "Orange", "Lemon", "Apple", "Mango"]
数组排序 - sort(func)
sort 方法用于对数组的元素进行排序。
sort 可接受一个参数 func,非必传,如果要传入必须是函数,在不传参的情况下,sort 表示按字符串编码的顺序进行排序,如果要对数组进行排序需传入函数。
不传参:
var arr= ["George", "John", "Thomas", "James", "Adrew", "Martin"];
arr.sort();
console.log(fruits); // ["Adrew", "George", "James", "John", "Martin", "Thomas"]
// 没有传入函数,所以结果是按照0123456789的顺序进行排列
var nums = [21,14,26,11,105];
nums.sort();
console.log(nums); // [105, 11, 14, 21, 26]
传参:
function sortNumber(a, b){
return a - b
}
var nums = [21,14,26,11,105];
nums.sort(sortNumber);
console.log(nums); // [11, 14, 21, 26, 105]
在指定位置添加/删除/替换元素 - splice( start, count , .....)
splice 接受多个参数,第一个是起始位置,第二个为删除个数,之后的参数为添加/删除/替换的元素。
splice 返回删除元素的数组
用法一 (添加元素)
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2,0,"Lemon","Kiwi");
console.log(fruits ); // ["Banana", "Orange", "Lemon", "Kiwi", "Apple", "Mango"]
用法二 (替换元素)
// 从第二个位置起删除两个元素,接受新的两个元素
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var a = fruits.splice(2,2,"Lemon","Kiwi");
console.log(a); // ["Apple", "Mango"]
console.log(fruits); // ["Banana", "Orange", "Lemon", "Kiwi"]
用法三 (删除元素)
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var a = fruits.splice(2,2);
console.log(a); // ["Apple", "Mango"]
console.log(fruits); // ["Banana", "Orange"]
在数组开头添加元素 - unshift()
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.unshift("Lemon","Pineapple");
console.log(fruits); // ["Lemon", "Pineapple", "Banana", "Orange", "Apple", "Mango"]
检查某元素是否存在于数组中 - indexOf()、lastIndexOf()
indexOf 和 lastIndexOf 都接受两个参数,第一是需要检查的元素。第二个是从那个索引位置开始检查
indexOf 表示从 0 开始,lastIndexOf 表示最后一个元素开始
var arr = [1,23,4,5,6,7,89];
arr.indexOf(89) // 6
arr.indexOf(89,2) // 6
arr.lastIndexOf(89) // 6
arr.lastIndexOf(89,5) // -1
数组遍历 - map()、forEach()
相同点:
都是数组的遍历方法,可以遍历数组中的每一个元素
forEach和map方法里每次执行匿名函数都支持3个参数,参数分别是item(当前每一项),index(索引值),arr(原数组)
都不会改变原数组
匿名函数的 this 都指向 windows
不同点:
map 方法会返回一个新的数组,数组中的元素为处理后的值,forEach 方法不会返回新的数组
map 方法不会对空数组进行检测,forEach对于空数组是不会调用回调函数的。
map 方法不支持低端浏览器
var arr = [1,2,3,4];
var a = arr.map(function(item,index,arr){
return item * item;
})
console.log(a); // [1, 4, 9, 16]
console.log(arr); // [1, 2, 3, 4]
var arr = [1,2,3,4];
var a = arr.forEach(function(item,index,arr){
return item * item;
})
console.log(a); // undefined
console.log(arr); // [1, 2, 3, 4]
数组过滤 - filter()
filter() 方法是返回某一数组中满足条件的元素,该方法返回的是一个新的数组。
// 返回元素长度大于 10 的数组元素
var arr = [12,5,8,16,125,98];
var filters = arr.filter(function(value){
return value >= 10
});
console.log(filters ); // [12, 16, 125, 98]
of 遍历
let arr2=[1,2,234,'sdf',-2];
for(let a of arr2){
console.log(a) // 1,2,234,sdf,-2 遍历了数组arr的值
}
数组累加器 - reduce()、reduceRight()
reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。
reduce 和 reduceRight 用法一样,区别在于 reduceRight 是从数组的末尾向前做数组项累加。
array.reduce(function(total, currentValue, currentIndex, arr), initialValue);
total 必需。初始值, 或者计算结束后的返回值。
currentValue 必需。当前元素
currentIndex 可选。当前元素的索引
arr 可选。当前元素所属的数组对象。
initialValue 初始值
var numbers = [65, 44, 12, 4];
var a = numbers.reduce(function(total,num){
return total + num;
},0)
console.log(a); // 125
判断数组中的元素是否满足指定条件 - some()、every()
some 方法会遍历数组的每一个元素,判断是否满足条件,返回一个布尔值。
every 方法会遍历数组的每一个元素,判断每一项是否满足条件,如果每项都满足,才返回true。
var numbers = [65, 44, 12, 4];
var a = numbers.some(function(item){
return item > 62;
});
console.log(a); // true
var numbers = [65, 44, 12, 4];
var a = numbers.every(function(item){
return item > 62;
});
console.log(a); // false
将当前数组指定位置的元素复制到其他位置并替换 - copyWithin(index,start,end)
index(必需):从该位置开始替换数据。如果为负值,表示倒数。
start(可选):从该位置开始读取数据,默认为 0。如果为负值,表示倒数。
end(可选):到该位置前停止读取数据,默认等于数组长度。使用负数可从数组结尾处规定位置。
[1, 2, 3, 4, 5].copyWithin(0,1,3) // [2, 3, 3, 4, 5]
JSON数组格式转换 - Array.from()
Array.from() 转换的 json 要求必须要有length属性
let people = {
0:'zhangsan',
'1':24,
length:2
};
let trans=Array.from(people);
console.log(trans); // ['zhangsan',24]
将一堆元素转换成数组 - Array.of()
let arr = Array.of(1,"23","测试","dsa");
console.log(arr); // [1, "23", "测试", "dsa"]
查找数组中满足条件的元素 - find()
let arr=[1,2,3,"cxz",-2];
var a = arr.find(function(x){
return x<="cxz";
});
console.log(a); // "cxz"
查找数组中满足条件的元素的下标 - findIndex()
let arr=[1,2,3,"cxz",-2];
var a = arr.findIndex(function(x){
return x<="cxz";
});
console.log(a); // 3
判断数组中是否包含某元素 - includes()
includes 判断数组中是否包含某元素,返回布尔值
let arr=[1,2,3,"cxz",-2];
var a = arr.includes("cxz");
console.log(a); // true
最后欢迎大家关注我的个人公众号,互联网码农,专注互联网编程技术分享,关注公众号,回复关键字,可以领取系列编程学习视频哦,前端、java、ios、安卓、c++、python应用尽有。
Javascritp Array数组方法总结的更多相关文章
- JavaScript Array 数组方法汇总
JavaScript Array 数组方法汇总 1. arr.push() 从后面添加元素,返回值为添加完后的数组的长度 var arr = [1,2,3,4,5] console.log(arr.p ...
- JavaScript Array数组方法详解
Array类型是ECMAScript中最常用的引用类型.ECMAScript中的数据与其它大多数语言中的数组有着相当大的区别.虽然ECMAScript中的数据与其它语言中的数组一样都是数据的有序列表, ...
- es6 Array数组方法
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- Array数组方法的总结
添加元素: 1. push(arg1,arg2,arg3....) 向数组的尾部添加元素,返回值是数组的长度. 2.unshift(arg1,arg2,arg3....) 向数组的头部添加元素,返回 ...
- js Array 数组方法扩展
//去重复 Array.prototype.unique = function() { this.sort(); var re=[this[0]]; for(var i ...
- JavaScript之数组方法整理
Array概述 除了Object类型,最常用的类型: 实质:有序的数据列表, 特性:可以动态的调整数组的大小 创建数组的两种方式 构造函数创建方式 var arr = ...
- JavaScript的json和Array及Array数组的使用方法
1.关于json JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集.也可以称为数据集和数组类似,能够存数据! //Ar ...
- JavaScript引用类型之Array数组之强大的splice()方法
splice()方法可以说是Array数组最强大的方法,他的用法很多,主要用法是向数组的中部插入项! 下面是它的用法: arrayObject.splice(index,howmany,element ...
- JavaScript引用类型之Array数组的toString()和valueof()方法的区别
一.转换方法 1.在JavaScript中几乎所有对象都具有toLocaleString().toString和valueof()方法,因为,所有的对象都继承自Object,而前面所说的方法都是Obj ...
随机推荐
- 按钮显示隐藏div、input等
<script type="text/javascript"> function show() { var value = document.getElementByI ...
- 前端速查手册——Note
目录 自定义弹框(模块框) HTML5新增标签 HTML5新增属性 自定义弹框(模块框) HTML <div style="display:none" id="mo ...
- sklearn使用高斯核SVM显示支持向量
import graphviz import mglearn from mpl_toolkits.mplot3d import Axes3D from sklearn.datasets import ...
- Unity3d基于Socket通讯例子(转)
按语:按照下文,服务端利用网络测试工具,把下面客户端代码放到U3D中摄像机上,运行结果正确. http://www.manew.com/thread-102109-1-1.html 在一个网站上看到有 ...
- 【使用kubectl apply xxx.yaml的方式从docker源拉取镜像】
只需要修改黄底色部分就可以了 apiVersion: apps/v1 # Kubernetes version 1.8.x should use apps/v1beta2 # Kubernetes v ...
- fiddler构造表单上传文件的请求
Fiddler使用技巧:http://www.doc88.com/p-3307506524682.html Fiddler构造post请求,在请求header头里加上下面语句,提交的body才会被解析 ...
- C#图片水印类
这个是学习用的呃,主要看一下水印在修改图片中距左边的宽度和高度是杂弄的就哦客了. using System; using System.Collections.Generic; using Syste ...
- centos下通过yum安装redis-cli
redis在第三方的源里,首先添加源,最常用的是epel源 yum install epel-release 然后就可以安装redis了 yum install -y redis 安装完成以后配置文件 ...
- nnexus3 破解密码
主要步骤如下: 1.停服 2.进入OrientDB控制台:java -jar /usr/local/nexus/lib/support/nexus-orient-console.jar 3.在控制台执 ...
- Charles 抓包配置
本文参考:charles 抓包配置 proxy setting (代理设置) 设置的主界面如下: 动态端口 启用动态端口选项来监听动态端口,每次查询启动时选择.这样可以避免与计算机上可能运行的其他网络 ...