Array类型

ECMAScript数组与其它语言数组一样,都是数据的有序列表。但是ECMAScript数组的每一项可以保存任何类型的数据。而且,ECMAScript数组是可以动态调整的。

1.创建和修改数组

·创建数组

 var colors=new Array(20);      //创建长度位20的数组
var colors=Array(20); //可以省略new操作符
var colors=Array("red","blue","green"); //数组字面量表示法
var colors=["red","blue","green"];
var values=[1,2,3];

·修改数组

 var colors=["red","blue","green"];
alert(colors[0]); //显示第一项
colors[2]="black"; //修改第三项
colors[3]="brown"; //新增第四项

·数组的length活用

数组的length不是只读的,重新设置length可以移出项,修改项,新增项,修改数组的长度。

2.检测数组----Array.isArray()

3.转换方法

toString():返回以逗号隔开的字符串     丨     valueOf():返回的是数组       丨      alert():会在后台调用toString()方法,而不是toLocaleString()方法     丨      join():参数是符号,此符号将代替逗号隔开字符串

4.栈方法和队列方法

栈方法:push():在末尾添加      pop():获得最后一项并移除

队列方法:shift():在首项移除       unshift():在首项添加

5.数组重排序

reverse()方法:反转数组的顺序     丨     sort()方法:按照传入的函数重新排序

比较函数:

 function compare(value1,value2){
return value2-value1;
};

6.操作方法

concat():先复制已有的数组,然后将参数添加到副本的末尾,如果参数是值,则直接添加,如果参数是数组,则将每一项都添加到副本的末尾。往一个数组后面加很多项用此方法。

 var colors=["red","green","blue"];
var colors2=colors.concat("yellow",["black","brown"]);
alert(colors); //red,green,blue
alert(colors2); //red,green,blue,yellow,black,brown

slice():从原数组中截取某一部分用此方法

 var colors=["red","blue","green","black","yellow"];
var colors2=colors.slice(1); //从第二个数到最后
var colors3=colors.slice(1,4); //从第二个数到第五个数,但是不包括第五个数
alert(colors2); //blue,green,black,yellow
alert(colors3); //blue,green,black
//如果参数里有负数,则用数组长度加上该数来确定相应的位置

splice():最强大的数组操作方法

 /*spice()方法是最强大的数组方法,它有三个参数 ,依次为起始位置,要删除的项数,要添加的项*/
var colors=["red","green","blue"];
var removed=colors.splice(0,1); /*删除第一行*/
alert(colors); /*green,blue*/
alert(removed); /*red,返回的数组中只包含一项,即删除的那一项*/ removed=colors.splice(1,0,"yellow","orannge"); //从位置一开始插入两项
alert(colors); //green,yellow,orange,blue注意,yellow在位置1
alert(removed); //返回的是一个空数组 removed=colors.splice(1,1,"red","purple"); //插入两项,删除一项
alert(colors); //green,red,purple,orange,blue
alert(removed); //yellow,返回的数组中只包含一项
/*注意,splice()返回的是删除的项,而不是改变后的原数组*/

7.迭代方法

every():每一项运行函数,只有每一项都返回true,最后才返回true

some():每一项都运行函数,任一项返回true最后就会返回true

forEach():不会返回值,作用其实和for循环一样

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

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

 /*every()和some()返回true或者false,不同的是,运行函数,every要求函数对每一项都返回true才会返回true,而some只要求任一项返回true就返回true*/
var numbers=[1,2,3,4,5,4,3,2,1]; var everyResult=numbers.every(function(item,index,array){
return(item>2);
});
alert(everyResult); //false var someResult=numbers.some(function(item,index,array){
return(item>2);
});
alert(someResult); //true /*filter()每一项运行函数,返回该函数会返回true的项组成的数组*/
var numbers=[1,2,3,4,5,4,3,2,1];
var filterResult=numbers.filter(function(item,index,array){
return(item>2);
});
alert(filterResult); //[3,4,5,4,3] /*forEach()不返回值,作用其实for循环一样*/ /*map()方法:每一项运行函数,返回每次函数调用的结果组成的数组*/
var numbers=[1,2,3,4,5,4,3,2,1];
var mapNumbers=numbers.map(function(item,index,array){
return item*2;
});
alert(mapNumbers); //2,4,6,8,10,8,6,4,2

8.归并方法

reduce()和reduceRight()方法都会迭代数组的每一项,然后构建一个最终返回的值。reduce()正序,reduceRight()逆序。这两个方法都接收两个参数:在每一项上调用的函数和最为归并的初始值。而这个函数接收4个参数

前一个值,当前值,项的索引和数组对象。这个函数返回的任何值都会作为一个参数返回给下一项。第一次迭代发生在数组的第二项,因此,第一个参数是数组的第一项,第二个参数是数组的第二项。

 var values=[1,2,3,4,5];
var sum=values.reduce(function(prev,cut,index,array){
return prev+cut;
},5);
alert(sum); //
/*这两个方法都接收两个参数:一个在每一项上调用的函数和(可选)作为归并基础的初始值。传给reduce()和reduceRight()的函数接收4个参数
前一个值,当前值,项的索引和数组对象。这个函数返回的任何值都会作为第一个参数自动传给下一项。第一次迭代发生在数组的第二项。因此第一个参数是数组的第一项
第二个参数是数组的第二项。
* */

9.位置方法

indexOf():正序索引          lastIndexOf():逆序索引          在比较参数和数组中的项时,必须严格相等,相当于使用===操作符,没有找到返回-1

 var numbers=[1,2,3,4,5,4,3,2,1];
alert(numbers.indexOf(4)); //
alert(numbers.lastIndexOf(4)); // alert(numbers.indexOf(4,4)); //5 从第五的数开始往后检索,所以第一个4并没有被检索到
alert(numbers.lastIndexOf(4,4)); //3 从倒数第五个数开始检索 var person={name:"Nicholas"};
var people=[{name:"Nicholas"}]; var morePeople=[person]; alert(people.indexOf(person)); //-1
alert(morePeople.indexOf(person)); //

引用类型之Array类型的更多相关文章

  1. JavaScript引用类型之Array类型一

    一.简介 除了Object之外,Array类型恐怕是ECMAScript中最常用的类型了.下面就来分析ECMAScript中的数组与其他语言中的数组的异同性: 1.相同点: (1)他们都是数据的有序列 ...

  2. JavaScript引用类型之Array类型API详解

    Array类型也是ECMASCRIPT中最常见的数据类型,而且数据的每一项可以保存任何类型的数值,而且数组的大小是可以动态调整的,可以随着数据的添加自动增长以容纳新的数据.下面,总结数据的一些常用方法 ...

  3. JavaScript之引用类型(Array类型)

    除了Object类型,Array是ECMAScript中最常用的类型了. 与其他语言不同的是,ECMAScript数组的每一项可以保存任何类型的数据. 而且,ECMAScript数组的大小是可以动态调 ...

  4. Javascript高级编程学习笔记(13)—— 引用类型(2)Array类型

    除了Object类型之外ECMA中最常用的引用类型可能就是Array类型了 并且ECMA中的数组类型和其他大多数编程语言的数组类型存在着很大的区别 今天就介绍一下JS中的Array的特别之处 区别 1 ...

  5. JavaScript的进阶之路(三)引用类型之Object类型和Array类型

    引用类型 Object类型 function a(num){ if(num>3){ a(--num); } console.log(num); } a(5); //如何创建对象的实例 var o ...

  6. 引用类型--Object类型、Array类型

    引用类型的值(对象)是引用类型的一个实例.在ECMAScript中,引用类型是一种数据结构,它描述的是一类对象具有的属性和方法. 对象是某个特定引用类型的实例,新对象是使用new操作符后跟一个构造函数 ...

  7. JS高程5.引用类型(2)Array类型

    Array类型: ECMAScript数组的每一项可以保存任何类型的数据,数组的大小是可以动态调整的. 创建数组的基本方式: (1)使用Array构造函数 var color=new Array(); ...

  8. JS_高程5.引用类型(2)Array类型

    Array类型: ECMAScript数组的每一项可以保存任何类型的数据,数组的大小是可以动态调整的. 创建数组的基本方式: (1)使用Array构造函数 var color=new Array(); ...

  9. 5.2 Array类型介绍

    Array类型是数组类型,Array(数组)类型也是引用类型中的一种. js 数组中的每一项可以保存任何类型的数据. js数组的大小/长度是可以动态调整的.如果你往数组中添加数据,数组长度会自动增加. ...

随机推荐

  1. RT-Thread学习笔记(1)

    前几天我在看uCOS-II的东西,看来看去一直没什么头绪.还有一点是,我很介意它现在是个商业软件,在官网下载东西,半天下完结果只有个lib,没有源代码.只能去其他地方下载老版本. 我还很介意不是在官方 ...

  2. Java模拟登陆【转载】

    import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.i ...

  3. TC srm 673 300 div1

    TC srm.673 300 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 Description 给你n(n<=50)匹马和n个人,一匹马和一个人能 ...

  4. Codeforces gym 100685 A. Ariel 暴力

    A. ArielTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/100685/problem/A Desc ...

  5. Jquery中$与$.fn的差别

    当今web开发往往离不开Jquery的使用,Jquery以其简洁的使用方式.良好的浏览器兼容性赢得了软件研发同行的青睐,作为当中的一员,自然也不例外,虽然刚開始时非常排斥Jquery,今天我谈一下对J ...

  6. Python标准库:迭代器Itertools

    Infinite Iterators: Iterator Arguments Results Example count() start, [step] start, start+step, star ...

  7. asp.net 实现“九连环”小游戏

    asp.net 实现"九连环"小游戏 wildcatsky(原作) public Class ChinaRing1  Inherits System.Web.UI.Page #Re ...

  8. Python学习 之 switch语句

    1.python并没有提供switch语句,python可以通过字典实现switch语句的功能,实现方法分为两步 —首先,定义一个字典 —其次,调用字典的get()获取相应的表达式 通过字典调用函数 ...

  9. Monolog - Logging for PHP 5.3+

    Monolog 是PHP的一个日志类库.相比于其他的日志类库,它有以下的特点: 功能强大.可以把日志发送到文件.socket.邮箱.数据库和各种web services. 遵循 PSR3 的接口规范. ...

  10. Windows 之 获取管理员权限

    新建文本文档,写入如下内容: Windows Registry Editor Version 5.00 [-HKEY_CLASSES_ROOT\*\shell\runas] [HKEY_CLASSES ...