合并数组 - 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数组方法总结的更多相关文章

  1. JavaScript Array 数组方法汇总

    JavaScript Array 数组方法汇总 1. arr.push() 从后面添加元素,返回值为添加完后的数组的长度 var arr = [1,2,3,4,5] console.log(arr.p ...

  2. JavaScript Array数组方法详解

    Array类型是ECMAScript中最常用的引用类型.ECMAScript中的数据与其它大多数语言中的数组有着相当大的区别.虽然ECMAScript中的数据与其它语言中的数组一样都是数据的有序列表, ...

  3. es6 Array数组方法

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  4. Array数组方法的总结

    添加元素: 1. push(arg1,arg2,arg3....)  向数组的尾部添加元素,返回值是数组的长度. 2.unshift(arg1,arg2,arg3....) 向数组的头部添加元素,返回 ...

  5. js Array 数组方法扩展

    //去重复   Array.prototype.unique = function()  {     this.sort();     var re=[this[0]];     for(var i ...

  6. JavaScript之数组方法整理

    Array概述      除了Object类型,最常用的类型:      实质:有序的数据列表,      特性:可以动态的调整数组的大小 创建数组的两种方式 构造函数创建方式  var arr = ...

  7. JavaScript的json和Array及Array数组的使用方法

    1.关于json JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集.也可以称为数据集和数组类似,能够存数据! //Ar ...

  8. JavaScript引用类型之Array数组之强大的splice()方法

    splice()方法可以说是Array数组最强大的方法,他的用法很多,主要用法是向数组的中部插入项! 下面是它的用法: arrayObject.splice(index,howmany,element ...

  9. JavaScript引用类型之Array数组的toString()和valueof()方法的区别

    一.转换方法 1.在JavaScript中几乎所有对象都具有toLocaleString().toString和valueof()方法,因为,所有的对象都继承自Object,而前面所说的方法都是Obj ...

随机推荐

  1. ubuntu上安装jdk

    使用安装包安装:JDK官网下载地址: https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.h ...

  2. ISO/IEC 9899:2011 条款6.3——转换

    6.3 转换 1.有些操作符将操作数的值自动地从一种类型转换为另一种.本子条款指定了从这么一个隐式转换所要求的结果,以及从一个投射操作(一个显式转换)所要求的结果.在6.3.1.8中所列出的信息概括了 ...

  3. 网页开启QQ会话

    在网页中开启QQ会话是很常见的,那么到底怎么调用了. 一.首先要被开启的QQ开启推广服务.注意这个一般开启难免被骚扰,所以不要用生活号. 传送门:https://www.xinxiangseo.cn/ ...

  4. Qt 操作excel报错

    onecore\com\combase\catalog\catalog.cxx(2376)\combase.dll!00007FFF1DF823CB: (caller: 00007FFF1DED3A1 ...

  5. Spring cloud微服务安全实战-4-3常见的微服务安全整体架构

    整体架构 这个图适合中小公司.麻雀虽小 五脏俱全.微服务架构所需要做的事在这个图里基本都有了. 绿色的不讲,主要讲的是这三块(橘黄色的).后面的和运维相关,会讲,不会讲的太深 订单服务 首先来写一个订 ...

  6. mysql登录指令

    mysql -h 192.168.1.124 -u root -p -h后加mysql的ip,-u加用户名,-p会弹出输入密码

  7. Linux的桌面虚拟化技术KVM(五)——virsh常用命令

    Linux的桌面虚拟化技术KVM(一)——新建KVM虚拟机 Linux的桌面虚拟化技术KVM(二)——远程桌面管理 Linux的桌面虚拟化技术KVM(三)——KVM虚拟机克隆和快照 Linux的桌面虚 ...

  8. 编译安装hls协议切片工具 m3u8-segmenter

    操作系统:Ubuntu16.04.4 amd64 安装http://m3u8-segmenter.inodes.org/方式安装m3u8-segmenter报错,于是有了这篇文章 apt instal ...

  9. python logging模块日志输出

    import logging logger = logging.getLogger(__name__) logger.setLevel(level = logging.INFO) handler = ...

  10. ROS初探--意义、基本模块

    顾虑就使我们都变成了懦夫,使得那果断的本色蒙上了一层思虑的惨白的容颜,本来可以做出伟大的事业,由于思虑就化为乌有了,丧失了行动的能力.-----哈姆雷特 ROS: Robot Operating Sy ...