JAVASCRIPT引用类型之Array类型(二)

本文深入讲解了JavaScript数组的各种方法,包括栈方法(如push和pop)、队列方法(如shift和unshift)、重排序方法(如reverse和sort)。通过实例演示了如何利用这些方法高效地操作数组。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Array类型

数组继承的toLocalString() , toString() 和 valueOf() 方法输出,在默认情况下都会以逗号分隔的字符串的形式返回数组想。而如果使用join方法,则可以使用不同的分隔符来构建这个字符串。join()方法只接受一个参数,即用作分隔符的字符串,然后返回包含所有数组项的字符串。如下:

var colors = ["red", "green", "blue"];
alert(colors.join(","));        //red,green,blue
alert(colors.join("|"));        //red|green|blue
alert(colors.join(undefined));  //red,green,blue

栈方法:

ECMAScript数组提供了一种让数组的行为类似于其他数据结构的方法。具体说来,数组可表现的就像栈一样,后者是一种可以限制插入和删除项的数据结构。栈是一种LIFO(Last-In-First-Out, 后进先出)的数据结构,也就是最新添加的项最早被移除。而栈中项的插入(叫做推入)和移除(叫做弹出),只发生在一个位置--栈的顶部。ECMAScript为数组专门提供了push() 和 pop() 方法,以便实现类似栈的行为。

push() 方法可以接收任意数量的参数,把他们逐个添加到数组末尾,并返回修改后数组的长度。而pop() 方法则从数组的末尾移除最后一项,减少数组的length值,然后返回移除的项。如下:

var colors = ["red", "green", "blue"];
alert(colors + " -> " + colors.length);     //red,green,blue -> 3
var pu = colors.push("black");
alert(pu);                                  //4
alert(colors + " -> " + colors.length);     //red,green,blue,black -> 4
pu = colors.push("pink", "white");
alert(pu);                                  //6
alert(colors + " -> " + colors.length);     // red,green,blue,black -> 6
var po = colors.pop();
alert(po);                                  //white
alert(colors + " -> " + colors.length);     //red,green,blue -> 5

队列方法:

栈数据结构的访问规则是LIFO(后进先出), 而队列数据结构的访问规则是FIFO(First-In-First-Out,先进先出)。队列在列表的末端添加项,从列表的前端移除项。由于push() 是想数组末端添加项的方法,因此要模拟队列只需一个从数组前端取得项的方法。实现这一操作的数组方法是shift(), 它能够移除队列数组中的第一个项并返回该项,同时将数组长度减1。结合使用shift() 和 push() 方法,可以像使用队列一样使用数组。

var colors = new Array();
var count = colors.push("red", "green");
alert(count);                   //2

count = colors.push("black");
alert(count);                   //3

var item = colors.shift();
alert(item);                    //red
alert(colors.length);          //2

ECMAScript还未数组提供了一个unshift()方法。顾名思义,unshift() 与 shift() 的用途想法:它能在数组前端添加任意个项并返回数组的长度。因此可以同时使用unshift() 和 pop() 方法,可以从相反的方向来模拟队列,即在数组的前端添加项,从数组末端移除项,如下:

var colors = new Array();
var count = colors.unshift("red", "green");
alert(count);                   //2

count = colors.unshift("black");
alert(count);                   //3

var item = colors.pop();
alert(item);                    //green
alert(colors.length);          //2

重排序方法:

数组中已经存在两个可以直接用来重排序的方法:reverse() 和 sort() 。 reverse() 方法会对反转数组项的顺序。如下:

var values = [1, 2, 3, 4, 5];
alert(values);      //1,2,3,4,5
values.reverse();
alert(values);      //5,4,3,2,1

在默认情况下,sort() 方法按升序方法排列数组想--即最小的值位于最前面,最大的值排在最后面。为了实现排序,sort()方法会调用每个数组项的toString()转型方法,然后比较得到的字符串,以确定如何排序。即使数组中的每一项都是数组,sort()方法比较的也是字符串,如下:

var values = [0, 1, 5, 10, 15];
alert(values);      //0,1,5,10,15
values.sort();
alert(values);      //0,1,10,15,5

可见,即使例子中值的顺序没有问题,但sort() 方法也会根据测试字符串的结果改变原来的顺序。因为数值5虽然小于10,但在进行字符串比较式, “10”则位于“5”的前面,于是数组的顺序就被修改了。这种排序方式在很多情况下都不是最佳方案。因此sort()方法可以接收一个比较函数作为参数,以便我们指定哪个值位于哪个值的前面。

比较函数接收两个参数,如果第一个参数应该位于第二个之前则返回一个负数,如果两个参数相等则返回0, 如果第一个参数应该位于第二个之后则返回一个正数。如下:

function compare(value1, value2) {
    if (value1 < value2) {
        return -1;    
    } else if (value1 > value2) {
        return 1;
    } else {
        return 0;
    }
}

这个比较函数适用于大多数数据类型,只要将其作为参数传递给sort()方法即可,如下:

function compare(value1, value2) {
    if (value1 < value2) {
        return -1;
    } else if (value1 > value2) {
        return 1;
    } else {
        return 0;
    }
}

var values = [0, 1, 5, 10, 15];
alert(values);      //0,1,5,10,15
values.sort(compare);
alert(values);      //0,1,5,10,15

对于数值类型或者其valueOf() 方法会返回数值类型的对象类型,可以使用一个更简单的比较函数。这个数值只要用第二个值减第一个值即可:

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

如下:

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

function Person(age) {
    this.age = age;
}

Person.prototype.valueOf = function() {
    return this.age;
}

var person1 = new Person(23);
var person2 = new Person(25);
var pesron3 = new Person(24);

var persons = [person1, person2, pesron3];
alert(persons[0].age + " -> " + persons[1].age + " -> " + persons[2].age);  //23 -> 25 -> 24
persons.sort(compare);
alert(persons[0].age + " -> " + persons[1].age + " -> " + persons[2].age);  //23 -> 24 -> 25

在上例中重写了Person() 构造函数原型的valueOf() 方法(重写toString()方法也可以实现,但是重写toLocaleString()方法不行)。

 

备注: 摘取自《JAVASCRIPT高级程序设计:第3版》

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值