JavaScript数组基本用法

其实数组,字符串等等都是在刚开始学js的时候就开始接触了,那个时候只是进行了简单的API学习,甚至连API都还没能够记住。经过几次这样的痛苦折磨,终于决定来写一篇博文来强化一下记忆,当然里面会加入一些自己的理解。

1 稀疏数组

至于如何创建数组,创建数组有哪几种方式,我在这里就不在叙述。首先来讲讲什么是稀疏数组。

稀疏数组就是包含从0开始的不连续索引的数组,通常稀疏数组的长度length属性值会大于数组的元素的个数。举个例子

     //如何产生稀疏数组
        var arr04=[];
        arr04[9]=1;
        alert(arr04.length)   //10
        alert(arr04[1]);      //undefined
        alert(1 in arr04);    //false

例子中我们定义了一个空数组,然后指定了arr04[9]=1,此时数组的length属性值是10,但是数组的元素个数只有1个,因为当我们用in来判断索引1处是否有元素返回的是false。没有元素默认返回的是undefined。当然如果是下面这样,会返回true。

     var arr03=[0,1,2,3,null,undefined];
        alert(4 in arr03);//判断索引4是否有值,即使该索引存入的值是null和undefined也会返回true
        alert(5 in arr03);

即使该索引存入的值是null和undefined也会返回true。

好了关于稀疏数组就说这么多,关于稀疏数组有什么用,什么地方会用到,小弟才疏学浅,目前不得而知。

2 删除数组元素

数组元素删除有4种方法:delete 操作符 、pop() 、shift()和splice()。而delete不会改变元素组的长度,只是把原数组变成了稀疏数组。而pop()和shift()都会直接改变数组的长度。splice()后面再讲。

而pop()方法是删除数组最高索引所指向的元素,shift()是删除最低索引所指向的元素即arr[0]。见例程:

        var arr05=[0,1,2,3];
        console.log(arr05.length+"---"+arr05);//4---0,1,2,3
        delete arr05[1];
        console.log(arr05.length+"---"+arr05);//---0,,2,3
        alert(1 in arr05)  //false
     var arr05=[0,1,2,3];
        arr05.pop()
        console.log(arr05.length+"---"+arr05);  //3---0,1,2   删除数组最后一个元素,长度会减一
       var arr05=[0,1,2,3];
        arr05.shift()
        console.log(arr05.length+"---"+arr05);  //3---1,2,3   删除数组第一个元素,长度会减一

3 数组遍历

相信最先想到得就是利用for循环,这也确实是一种不错的方法,这里就不在举例。

如果想利用这种方法在遍历数组的过程中跳过元素为null、undefined和不存在的元素,我们可以这样做:

     var arr06=[1,2,3,null,4,undefined,5,,];
        for(var i=0;i<arr06.length;i++){
            if(!arr06[i])continue;
            console.log(i+"----"+arr06[i]);
        }

当然还有遍历除存在的元素

     var arr06=[1,2,3,null,4,undefined,5,,];
        for(var i=0;i<arr06.length;i++){
            if(!(i in arr06))continue;
            console.log(i+"----"+arr06[i]);
        }

如果想跳过元素为undefined和不存在的元素,可以这么做:

     var arr06=[1,2,3,null,4,undefined,5,,];
     for(var i=0;i<arr06.length;i++){
            if(arr06[i]===undefined)continue;
            console.log(i+"----"+arr06[i]);
        }

然后就是利用for  in进行遍历。例:

     var arr06=[1,2,3];
        for(var index in arr06){
            console.log(index+"----"+arr06[index]);
        }

但是利用for in会有一个问题那就当我们自定义一些原型属性时,这些属性也是被遍历出来的。例:

     var arr06=[1,2,3];
        Array.prototype.test=5;
        for(var index in arr06){
            console.log(index+"----"+arr06[index]);
        }

当然数组内置的一些原型属性,例如join,map等等都是不可遍历的。所以一般不推荐使用这种方法,因为你可能不知道代码中别人是否在原型上面增加了方法或者属性,而导致最后for in遍历时多出了很多意料之外的结果。当然你可以采用下面的办法,把这些意料之外的结果剔除。

    for(var index in arr06){
            if(!arr06.hasOwnProperty(index))continue;
            console.log(index+"----"+arr06[index]);
        }

还有一种方法就是利用ES5新增方法-forEach()至于该方法的介绍大家可以参见我的这篇博文

4 数组基本方法

join():将数组中所有的元素都转换成字符串拼接在一起,最后返回这个字符串。它接受一个参数,表示每个元素之间的分隔符,当然该参数是可选的。Array.join是String.split的逆向操作。这一组操作是非常有用的,还望大家能够理解运用。见例程:

     var arr06=[1,2,3];
        var str="1-2-3";
        console.log(arr06.join("-"));  //1-2-3  已经转换为字符串
        console.log(str.split("-"));   //["1", "2", "3"]  已经转换为数组

reverse():就是将数组的元素顺序实现反转,比如原来是[1,2,3]实行该操作后就会变成[3,2,1]。这里我就不再举例了,想偷点懒了,写的太累了,也不想太啰嗦了。

sort():该函数是为数组元素实现排序的一个函数,如果不传参数的话,会将数组元素按照字符串进行排序,这里我们应该都知道,字符串比较大小,实际上是比较他们的ASCII值的大小,在ASCII码中“a”的ASCII码是97而“A”的ASCII码是65,97大于65,所以字符串的比较结果应该是“a”大于“A”。在sort函数中就是逐个比较两个元素中对应位置字符的ASCII的大小。例如:“abcd”和“abce”,前面三个字符“abc”都是一样的,实际上最后比较的是“d”和“e”的ASCII码值。

var arr07=["j","d","l"]
console.log(arr07.sort());//["d", "j", "l"]

当然如果数组元素是数字,那么sort函数会把数字转换成字符串进行比较,而不会进行真正的数值比价,见例程:

var arr07=[3,15,4]
console.log(arr07.sort());//[15, 3, 4]  应为“1”的ASCII码值小于“3”

如果要做到真正数值上的排序,这要给sort传入一个参数,这个参数就是一个比较函数。例:

     var arr07=[3,15,4]
        console.log(arr07.sort(function(a,b){
            return a-b;
        }));   //[3, 4, 15]

比较规则就是,假设第一个参数应该在前,比较函数应该返回一个小于0的值,在后返回一个大于0的值,如果两个数大小一样,谁在前面显得不是很重要就返回0。如果要是从大到小排,我们只需要改成 return b-a;

concat():数组拼接。直接上例程自行体会

     var arr08=[0,1,2];
        var arr09=[3,4];
        var arr10=[5,6];
        console.log(arr08.concat(arr09));//[0, 1, 2, 3, 4]
        console.log(arr08.concat(arr09,arr10));//[0, 1, 2, 3, 4, 5, 6]
        console.log(arr08.concat(arr09,arr10,[7,8,[9,10]]));//[0, 1, 2, 3, 4, 5, 6, 7, 8, [9,10]]

slice():返回指定数组的一个片段或者子数组。例程如下

     var arr11=[0,1,2,3,4,5,6];//
        console.log(arr11.slice(0,3));//[0, 1, 2]
        console.log(arr11.slice(3,1));//[]  这样获取的会是空数组
        console.log(arr11.slice(3));//[3, 4, 5, 6]  没有指定第二个参数,表示截取从第三个元素一直到最后的所有数组元素
        console.log(arr11.slice(0,-1));//[0, 1, 2, 3, 4, 5]  负数代表倒数第几个
        console.log(arr11.slice(-5,-3));//[2, 3]  截取从倒数第五个到倒数第3个之间的元素
        console.log(arr11.slice(-3,-5));//[]  空数组

splice():该方法是在数组中插入和删除元素的通用方法。它的第一个参数指定了插入或者删除的起始位置,第二个参数表示删除的个数,如果没有指定,则表示从删除从指定位置到数组结尾的所有元素,并最后返回这个删除的元素数组。如果没有删除元素则返回一个空数组。

     var arr12=[1,2,3,4,5,6,7,8];
        console.log(arr12.splice(4)+"--原数组:"+arr12);
        console.log(arr12.splice(1,2)+"--原数组:"+arr12);
        console.log(arr12.splice(1,1)+"--原数组:"+arr12);
        console.log(arr12.splice(1,0)+"--原数组:"+arr12);

splice()前两个参数指定了删除的起始位置和删除元素的个数,其后面任意个参数表示要插入的元素。例:

     arr12.splice(1,0,"djl");//[1, "djl", 2, 3, 4, 5, 6, 7, 8]
        arr12.splice(1,1,"djl");//[1, "djl", 3, 4, 5, 6, 7, 8]

push()和pop():

push()向数组末尾追加元素,pop():删除数组最后一个元素。都是会直接改变原数组的长度。不再举例了,累。

shift()和unshift()

shift():删除数组的第一个元素;unshift():在数组最前面添加一个元素。也都是会直接改变原数组的长度。

toString():将每个数组元素转化为字符串并且用逗号将每个元素进行分隔,这里和不传入参数的join方法所达到的效果是一样的。

目前就这么多了,已经够多了,能够耐心看到这里的,必须好好犒劳一下自己!

时间: 2024-12-29 17:39:08

JavaScript数组基本用法的相关文章

Javascript数组与字典用法分析

http://www.68idc.cn/help/makewebs/javascript/20141214142024.html 这篇文章主要介绍了Javascript数组与字典用法,以实例形式较为详细的分析了Array作为数组与字典的不同用法,具有一定的参考借鉴价值,需要的朋友可以参考下 本文实例分析了Javascript数组与字典用法.分享给大家供大家参考.具体分析如下: Javascript 的数组Array,既是一个数组,也是一个字典(Dictionary). 先举例看看数组的用法. 复

JavaScript数组知识网络

JavaScript数据类型 基本数据类型 Boolean Null Number String Symbol Undefined 对象数据类型Object Build-in object Array Date RegExp more... Array 定义:JavaScript数组是内置的对象之一,它可以用一个变量来存储多个同种类型或不同类型的值. 构造方法 var newArr = new Array(values); var newArr = [values]; 判断是否数组 Array.

深入浅出 JavaScript 数组 v0.5

本文来自:http://www.cnblogs.com/googny/p/3747832.html 有一段时间不更新博客了,今天分享给大家的是一篇关于JS数组的,数组其实比较简单,但是用法非常灵活,在工作学习中应该多学,多用,这样才能领会数组的真谛. 以下知识主要参考<JS 精粹>和<JavaScript 高级程序设计>. 数组是一段线性分配的内存,它通过整数计算偏移并访问其中的元素.JavaScript 没有像此类数组一样的数据结构. 它提供了一些类数组特性的对象,它把数组的下标

JavaScript的基本用法--博客园老牛大讲堂

我最近总结了关于javaScript的用法,下面分享给大家--关注博客园老牛大讲堂 数组的用法: var arr=[10,1,66,55,100,5,2,7,1]; var arr1=[4,8,11]; console.log(arr.push(4,8,11));//添加末尾元素,返回数组的长度 console.log("末尾添加元素:"+arr); console.log(arr.unshift(4,8,11));//添加头元素,返回数组长度 console.log("开头

javascript数组操作(创建、元素删除、数组的拷贝)

这篇文章主要介绍了javascript数组操作,包括创建.元素的访问.元素删除.数组的拷贝等操作,还有其它示例,需要的朋友可以参考下 1.数组的创建 复制代码 代码如下: var arrayObj = new Array(); //创建一个数组var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是上限,是长度var arrayObj = new Array([element0[, element1[, ...[, elementN]]]]); 创

javascript数组的使用

<!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> </head> <script type="text/javascript"> //数组的基本用法 //javascript的元素的类型可以随意放 var arr1=[2,4,6,8,10]; var sum=0; for(v

javascript 数组的深度复制

javascript 数组的深度复制 一般情况下,使用 "=" 可以实现赋值.但对于数组.对象.函数等这些引用类型的数据,这个符号就不好使了. 1. 数组的简单复制 1.1 简单遍历 最简单也最基础的方式,自然是循环处理.示例: function array_copy(arr) { var out = [], i, len; if (out[i] instanceof Array === false){ return arr; } for (i = 0, len = arr.lengt

[前端JS学习笔记]JavaScript 数组

一.JavaScript数组的奇葩 大多数语言会要求数组的元素是同个类型, 但是JavaScript允许数组元素为多种类型. var arr = ["羽毛球", 666, {"json:":"666"}]; console.log(arr.length); 二.JavaScript 数组的两种声明 1.var arr = [元素]; var arr = ["坚持"]; 2.new Array(); 或者 var arr2 =

JavaScript 数组去重

JavaScript 数组去重 Why underscore (觉得这部分眼熟的可以直接跳到下一段了...) 最近开始看 underscore.js 源码,并将 underscore.js 源码解读 放在了我的 2016 计划中. 阅读一些著名框架类库的源码,就好像和一个个大师对话,你会学到很多.为什么是 underscore?最主要的原因是 underscore 简短精悍(约 1.5k 行),封装了 100 多个有用的方法,耦合度低,非常适合逐个方法阅读,适合楼主这样的 JavaScript