定义:var colors=new Array();

  var colors=new Array(3);

  var colors=new Array('red');

  var colors=['red','green'];

检测数组:

  if (value instanceof Array) :假定只有一个全局执行环境。具体是不同框架有不同的定义

  Array.isAarry(value): ie9+,firefox4+,safari5+, opera10.5+

数组转换:所有对象都具有toLocaleString(),toString() 和valueOf();

  colors.toString();//red,blue,green ,上诉三个方法都是这样调用

  与 colors.join(',')效果一致。

栈方法:LIFO(Last-In-First-Out 后进先出) :最新添加的项最早被移除

  push():在数组末尾添加该项

  pop():在数组末尾移除最后项

队列方法:FIFO(First-In-First-Out先进先出) :在队列的末端添加项,从列表的前端移除项

  shift() :移除数组中的第一项

  unshift() :在数组前端添加任意个项

排序方法:

  values.sort();

  values.reverse();

操作方法:

  concat():可以基于当前数组中的所有项创建一个新的数组

例:var colors=[red,green]

  var colors2=colors.concat(yellow,[black,brown])

  alert(colors2.toString()) ;// red,green,yellow,black,brown

最强大的数组方法:splice() 主要用途是向数组的中部插入项

  删除:可删除任意数量的项,需指定两个参数:要删除的第一项的位置和要删除的项数

  例:splice(0,2)

  插入:可向指定的位置插入任意数量的项 ,需提供多个参数:起始位置,插入(删除)多少项,项值(....)

  例:splice(2,0,red,green) 从位置2开始插入两项

  替换:可向指定的位置插入任意数量的项,且同时删除任意数量的项,需指定三个参数:起始位置,要删除和插入的任意项

  例:splice(2,1,red,green),会删除位置2的项,从位置2开始插入两项

位置方法:

  indexOf():从数组开头开始向后查找

  lastIndexOf():从数组后面开始向前查找

  需要注意兼容:ie9+,firefox2+,safari3+等

迭代方法:定义了5个迭代方法

  var numbers=[1,2,3,4,5,4,3,2,1]

  every():对数组中的每一项运行给定函数,每一项都返回true,则返回true;

  例: var everyResult=numbers.every(function( item,index,array){ return (item>2) }) //返回false

  some():对数组中的每一项运行给定函数,有一项返回true,则返回true;

  例: var someResult=numbers.some(function( item,index,array){ return (item>2) }) //返回true

  filter():对数组中的每一项运行给定函数,返回该函数会返回true的项组成的数组

  例:var filterResult=numbers.filter(function( item,index,array){ return (item>2) }) //返回 {3,4,5,4,3}

  map():对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组

  例:var mapResult=numbers.map(function( item,index,array){ return (item*2)}) //返回{2,4,6,8,10.8.6.4.2}

forEach():对数组中的每一项运行给定函数,这个方法没有返回值

例:var numbers.forEach(function(item,index,array){  }) //本质于for循环一样

归并方法:迭代数组的所有项,然后构建一个最终返回的值

reduce():从数组的第一项开始,逐个遍历到最后

reduceRight():从数组的第一项开始,向前遍历到第一项

都接收四个参数:前一个值,当前值,项的索引,和数组对象

例:var values=[1,2,3,4,5]

var sum=values.reduce(function(prev,cur,index,array){  return prev+cur })

分析:第一轮:prev 1,cur 2,第二轮: prev 3,cur 3

javascript 之 数组的更多相关文章

  1. JavaScript Array数组方法详解

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

  2. JavaScript从数组中删除指定值元素的方法

    本文实例讲述了JavaScript从数组中删除指定值元素的方法.分享给大家供大家参考.具体分析如下: 下面的代码使用了两种方式删除数组的元素,第一种定义一个单独的函数,第二种为Array对象定义了一个 ...

  3. JavaScript中数组操作常用方法

    JavaScript中数组操作常用方法 1.检测数组 1)检测对象是否为数组,使用instanceof 操作符 if(value instanceof Array) { //对数组执行某些操作 } 2 ...

  4. javascript常用数组算法总结

    1.数组去重 方法1: JavaScript //利用数组的indexOf方法 function unique (arr) { var result = []; for (var i = 0; i & ...

  5. javascript中数组的22种方法

    × 目录 [1]对象继承 [2]数组转换 [3]栈和队列[4]数组排序[5]数组拼接[6]创建数组[7]数组删改[8]数组位置[9]数组归并[10]数组迭代[11]总结 前面的话 数组总共有22种方法 ...

  6. javascript中数组Array的方法

    一.常用方法(push,pop,unshift,shift,join)push pop栈方法,后进先出var a =[1,2,3];console.log(a.push(40)); //4 返回数组的 ...

  7. 第二章:javascript: 数组

    数组是编程世界里最常见的数据结构.任何一种编程语言都包含数组,只是形式稍微有差异.数组是编程语言中的内建类型,通常效率都很高.可以满足不同需求的数据存储,本章将探索javascript中的数组工作原理 ...

  8. JavaScript操作数组

    数组被描述为一个存储元素的线性集合,元素可以通过索引来任意存取. 几乎所有的编程语言都有类似的数据结构,但是Javascript中的数组却略有不同. Javascript中的数组是一种特殊的对象,所以 ...

  9. Javascript中数组

    Javascript中数组 1.什么是数组 所谓的数组就是一组数据的集合,在内存中表现为一段连续的内存地址(保存在堆内存) 2.创建数组的含义 创建数组的目的:就是为了保存更多的数据 3.数组的定义 ...

  10. JavaScript删除数组重复元素的5个高效算法

    之前一段时间一直在准备面试, 因而博客太久没更新: 现在基本知识点都复习完毕, 接下来就分享下 面试的一些常见问题: 去正规的互联网公司笔试.面试有很大的概率会碰到 使用javascript实现数组去 ...

随机推荐

  1. Exp5 MSF基础应用 20164320 王浩

    1. 实践目标 本实践目标是掌握metasploit的基本应用方式,重点常用的三种攻击方式的思路.具体需要完成: 1.1一个主动攻击实践,如ms08_067; (1分) 1.2 一个针对浏览器的攻击, ...

  2. LG3834 可持久化线段树1

    题意 给定\(N\)个整数构成的序列,将对于指定的闭区间查询其区间内的第\(K\)小值. $n \leq 2 \times 10^5 $ 思路 在\([l,r]\)区间内的数的个数,可以用\(sum[ ...

  3. html/jsp导出pdf格式的几种方法(jsPDF,iText,wkhtmltopdf)

    在许多生成报表的时候需要我们后台作出动态的数据,并渲染到前端生成pdf格式,Excel格式的各种报表,但是浏览器自带的生成pdf功能,windows系统的ctrl+p键就能完全搞定这一需求,但对客户来 ...

  4. Elasticsearch学习笔记(十二)filter与query

    一.keyword 字段和keyword数据类型    1.测试准备数据 POST /forum/article/_bulk { "index": { "_id" ...

  5. VScode 中 vue文件template中不能使用tab补齐标签

    选择 文件-->首选项-->设置-->搜索  emmet,选择 编辑 setting.json, 添加下列代码: "emmet.includeLanguages" ...

  6. 基于Dockerfile创建docker镜像

    0.先创建一个文件夹img mkdir img 1.Linux上新建3个文件 2.文件内容分别写入 (1)Dockerfile中 # 基于的基础镜像centos FROM centos # 维护该镜像 ...

  7. crypto++

    CryptoPP库是一个C++书写的加密算法库,很棒. 在如今的抛却数字证书体系下,只关注公私钥对的情况下,我认为存粹的加解密算法库很有市场,虽然我以前觉得PolarSSL的加解密算法实现不错,但不影 ...

  8. ehcarts 四川地图

    vue 首先你要傻子地图就引入进来(没得的地图需要你json请求得到(这个json自己去找),然后你要注册这个地图,echarts有的话就不用注册) import "../../node_m ...

  9. react github项目

    https://github.com/bailicangdu/react-pxq 网址;https://github.com/bailicangdu/react-pxq

  10. eval() 和 int()区别,以及eval作用

    eval()方法作用是将数据转换回原本的类型 a = str(list) type(a)--->str eval(a) type(a)--->list