总结 javascript 数组常用方法

纯个人总结,都是一些很基础的知识点,不是全部的方法,只有一些常用到的,方便以后查阅。

1、创建数组;
var arr = new Array();                //创建一个空数组;
var arr1 = new Array(3);               //创建一个包含3项的数组,每一项都是undefined;
var arr2 = new Array("3");              //创建一个数组,只有一项为字符串3;

2、常用方法
join();
此方法可以把数组转换为字符串,接受一个参数指定数组每一项的连接符;若不加参数,默认为逗号;
例如:
var arr=[2,3,4];                
arr.join('');                        // "234"
arr.join('+');                // "2+3+4"

split();
此方法可以字符串转为数组;
例如:
var str="https://www.baidu.com/s?wd=javascript&rsv_spt=1&rsv_iqid=0xb5b5ce2900000036&issp=1&f=3&rsv_bp=0&rsv_idx=2&ie=utf-8&tn=baiduhome_pg";  
str.split('?')[1].split('&');
//["wd=javascript", "rsv_spt=1", "rsv_iqid=0xb5b5ce2900000036", "issp=1", "f=3", "rsv_bp=0", "rsv_idx=2", "ie=utf-8", "tn=baiduhome_pg"]

push();
把元素从后面添加到数组;可以接受任意参数,返回数组的长度;
例如:
var arr=[2,3];
arr.push('d');                   // 3;
alert(arr);                        // [2,3,"d"];

pop();
从数组末尾删除最后一项,减少数组的长度;不加参数;返回删除项;
例如:
var arr=[1,2,3]; 
arr.pop();                        // 3;
arr;                                // [1, 2];

unshift();
把元素从前面添加到数组;可以接受任意参数,返回数组的长度;
例如:
var arr=[1,2,3]; 
arr.unshift(0);                 // 4
arr;                                // [0, 1, 2, 3]

shift();
删除数组的第一项,减少数组的长度;不加参数;返回删除项;
例如:
var arr=[0,1,2,3]; 
arr.shift();                        //0
arr;                                //[1, 2, 3]

reverser();
反转数组的顺序;不够灵活更多时使用sort()方法;
例如:
var arr=[2,3,4,5]; arr.reverse();
[5, 4, 3, 2]

sort();
对数组进行排序,默认为升序(由小到大);可接受比较函数作为参数来指定如何排列;
例如:
var a=[6,4,8,1,0,9,4,2]; 
a.sort(function(a,b){return a-b});                // [0, 1, 2, 4, 4, 6, 8, 9]
a.sort(function(a,b){return b-a});                // [9, 8, 6, 4, 4, 2, 1, 0]

concat();
创建并返回一个新的数组;不改变原有数组;
例如:
var a=[2,3,4];   
a.concat(["a","b"]);                //  [2, 3, 4, "a", "b"] 

slice();
截取当前数组创建并返回一个新的数组;一到两个参数,分别代表起始位置和结束位置之间的项,不包含结束位置的项,当只有第一个参数,代表从参数指定位置到结尾;
例如:
var arr=[3,2,"a","c",6,"e"];  
arr.slice(1,4);                        // [2, "a", "c"]
arr;                                        // [3, 2, "a", "c", 6, "e"]
arr.slice(4);                        // [6, "e"]

splice();
功能强大;可实现插入、替换、删除方法;参数有多个;会修改原数组;
        删除:可删除任意项,指定两个参数,分别代表 要删除第一项的位置和删除的项数。返回删除项
        例如:
        var arr=[3, 2, "a", "c", 6, "e"];  
        arr.splice(1,2);                        // [2, "a"]
        arr;                                        // [3, "c", 6, "e"]

        替换:在任意位置插入任意数量的项,同时删除任意数量的项,第一个参数为起始位置,第二个参数为要删除的项数,后面分别代表要插入的每一项。删除的项数和插入的项数可以不相等。
        例如:
        var arr=[3, 2, "a", "c", 6, "e"];   
        arr.splice(2,1,"insert0","insert1");  
        arr;                                // [3, 2, "insert0", "insert1", "c", 6, "e"]


        插入:在指定位置插入任意数量的项;第一个参数代表起始位置,第二个参数代表要插入的项0;如果是多个项,分别是为后面的参数
        例如:
        var a=[2,3,4];   
        a.splice(1,0,"insert0","insert1");
        a;                                // [2, "insert0", "insert1", 3, 4]




ECMAScript 5 新方法:
注意兼容性问题,支持 chrome , IE9+ , FF2+ , Safari3+ , Opera9.5+
map();
迭代数组;对每一项运行对应的函数,参数可选值:数组项的值,该项在数组中的位置,数组对象本身 ;不会修改原数组;返回函数调用的结果组成的数组;
var arr=[1,4,3];   
arr.map(function( res , n ){ return res+1 });                // [2, 5, 4]

forEach();
同map() 方法,迭代数组;对每一项运行对应的函数,无返回值;

posted on 2015-10-15 16:26  lily1115  阅读(138)  评论(0)    收藏  举报

导航