一.转换方法

  所有的对象都具有toLocaleString(),toString()和valueOf()方法。调用toString()方法会返回由数组中的每个值的字符串拼接而成的一个以逗号分隔的字符串。而调用valueOf()返回的还是数组。

  

valueOf() 方法返回 Array 对象的原始值。

该原始值由 Array 对象派生的所有对象继承。

valueOf() 方法通常由 JavaScript 在后台自动调用,并不显式地出现在代码中。

注意: valueOf() 方法不会改变原数组。

eg:

 var colors=["red","green","blue"];
alert(colors.toString()); //red","green","blue
alert(colors.valueOf()); //red","green","blue
alert(colors); //red","green","blue
alert(typeof(colors.toString()));//string
alert(typeof(colors.valueOf())); //object
alert(Object.prototype.toString.call(colors.valueOf()));//[object Array]

  由上面的例子可以看出,调用数组的toString()方法,返回的是数组的字符串形式,调用valueOf()方法返回的还是数组。这里需要注意的是,由于alert()要接收字符串参数,所以它会在后台调用toString()方法,因此会得到与直接调用toString()方法相同的结果。

toLocaleString()方法

  toLocaleString()方法也会创建一个数组值的以逗号分隔的字符串,与toString()和valueOf()不同的是它为了取得每一项的值,调用的是每一项的toLocaleString()方法,而不是toString()方法。

eg:

 var person1={
toLocaleString:function(){
return "toLocale1";
},
toString:function(){
return "toSt1";
}
}
var person2={
toLocaleString:function(){
return "toLocale2";
},
toString:function(){
return "toSt2";
}
}
var person=[person1,person2];
alert(person); //toSt1,toSt2,因为它调用的是toString方法。
alert(person.toString()); //toSt1,toSt2
alert(person.toLocaleString()); //toLocale1,toLocale2

  数组继承的toLocaleString(),toString()和valueOf()方法,在默认情况下都会以逗号分隔的字符串的形式返回数组项。使用join()方法,可以使用自定义的分隔符来构建这个字符串,join()方法只接受一个参数,即用作分隔符的字符串,然后返回使用数组项的字符串。

eg:

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

注意:

  (1)如果不给join()方法传入任何值,或者给它传入undefined,则使用逗号作为分隔符。IE7及更早的版本会错误的使用字符串“undefined”作为分隔符。

  (2)如果数组中的某一项的值是null或是undefined,那么该值join(),toLocaleString(),toString()和valueOf()方法返回的结果中以空字符串表示。

二.栈方法

  栈是一种LIFO(Last-In-First-Out 后进先出)的数据结构,即最新添加的项最早被移除。栈中项的插入(推入)和移除(弹出),值发生在栈顶。ECMAScript提供push()和pop()方法来实现类似栈的行为。

  1.push(),添加项,返回修改后的数组长度。

  2.pop(),减少,返回移除的项。

eg:

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

  栈方法可以和其他数组方法一起使用。

三.队列方法

  队列数据结构的访问规则是FIFO(First-In-First-Out,先进先出)。队列在列表的末端添加项,在列表的前端移除项。

  1.push()

  2.shift(),移除数组中的第一项,并且返回改项。

eg:

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

3.相反方向的队列,即在数组的前端添加项,在末端移除项。

(1)unshift(),添加,在数组的前端添加任意个项并返回数组的长度。

(2)pop()

eg:

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

注意:

  IE7及更早的版本对Javascript的实现中存在偏差,其unshift()方法总是返回undefined而不是数组的新长度,IE8在非兼容模式下会返回正确的长度值。

四.重排序方法

1.reverse()方法:反转数组项的顺序。

eg:

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

2.sort()方法:按升序排列数组项,即最小的值在最前面,最大的值在最后面,但是要注意的是:sort()方法会调用每个数组项的toString()方法转型方法,然后比较得到的字符串,以确定如何排序。即使数组中的每一项都是数值,sort()方法比较的也是字符串。

eg:

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

说明(W3C)

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

  • 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
  • 若 a 等于 b,则返回 0。
  • 若 a 大于 b,则返回一个大于 0 的值。

eg:

 function compare(value1,value2){
if(value1<value2){
return -1;
}else if(value1>value2){
return 1;
}else{
return 0;
}
}
var values=[1,2,3,4,5,10,11];
values.sort(compare);
alert(values);//1,2,3,4,5,10,11

  也可以通过改变比较函数的返回值,达到降序的效果:

eg:

 function compare(value1,value2){
if(value1<value2){
return 1;
}else if(value1>value2){
return -1;
}else{
return 0;
}
}
var values=[1,2,3,4,5,10,11];
values.sort(compare);
alert(values);//11,10,5,4,3,2,1

注意:

  (1)当然,如果是简单想反转原来的顺序,而不考虑升序降序的问题,使用reserve()要更快一些。

  (2)reverse()和sort()方法的返回值是经过排序后的数组。

  (3)对于数值类型或者是valueOf()方法会返回数值类型的对象模型,可以使用以下函数:

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

  由于比较函数通过返回一个小于0,等于0或是大于0的值来影响排序结果,因此减法操作就可以适当地处理这些情况。

JS高程5.引用类型(4)Array类型的各类方法的更多相关文章

  1. JS_高程5.引用类型(4)Array类型的各类方法

    一.转换方法 所有的对象都具有toLocaleString(),toString()和valueOf()方法.调用toString()方法会返回由数组中的每个值的字符串拼接而成的一个以逗号分隔的字符串 ...

  2. JS高程5.引用类型(3)Array类型-检测数组

    1. instanceof操作符(ECMAScript3) 对于一个网页,或者是一个全局作用域而言,使用instanceof操作符来检测数组就可以得到满意的结果. 语法:if(value instan ...

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

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

  4. Js高程笔记->引用类型

    1 . Object 对象    2 . Array 对象 :       检测方法:ES5 : isArray       转换方法: toLocaleString , toString , val ...

  5. 《JS高程》引用类型学习笔记

    2月圆满的结束了,结束之前是如凤凰般的涅槃.一边上班,一边搞科研的忙碌有点让人透不过气,心会不由得浮躁起来.但是,无论什么事情,只要充满耐心.专心去做,总会朝好的方向发展,心态真的很重要.Anyway ...

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

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

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

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

  8. 引用类型之Array类型

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

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

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

随机推荐

  1. Android之使用文件进行IPC

    一.文件进行IPC介绍 共享文件也是一种不错的进程间通信方式,两个进程通过读/写同一个文件来交换数据.在Windows上,一个文件如果被加了排斥锁将会导致其他线程无法对其进行访问,包括读写,而由于An ...

  2. 如何让我们的PHP在Jexus中跑起来

    最近一段时间,经常看到不少的朋友在问,应该怎么设置才能够让Jexus支持PHP.其实,Jexus在很早之前就已经是可以支持PHP,像Apache或Nginx一样充当PHP的Web服务器的.不过由于没有 ...

  3. 【腾讯Bugly干货分享】一步一步实现Android的MVP框架

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/5799d7844bef22a823b3ad44 内容大纲: Android 开发 ...

  4. ASP.NET MVC 描述类型(二)

    ASP.NET MVC 描述类型(二) 前言 上个篇幅中说到ControllerDescriptor类型的由来过程,对于ControllerDescriptor类型来言ActionDescriptor ...

  5. ABP配套代码生成器(ABP Code Generator)帮助文档,实现快速开发

    ABP代码生成器介绍 针对abp这个框架做了一个代码生成器,功能强大.分为两大功能点,一个是数据层,一个是视图层. 数据服务层:通过它,可以实现表设计.领域层初始化.多语言.automapper自动注 ...

  6. Web网站中利用JavaScript中ActiveXObject对象获取硬件信息(显示器数量、分辨率)从而进行单双屏跳转

    前言:最近这两天工作上,要实现一个功能,在好友阿聪的帮助下,算是比较好的解决了这个需求. B/S的Web网站,需要实现点击按钮时,根据客户端连接的显示屏(监视器)数量进行,单双屏跳转显示新页面. 由于 ...

  7. MSSQLSERVER执行计划详解

    序言 本篇主要目的有二: 1.看懂t-sql的执行计划,明白执行计划中的一些常识. 2.能够分析执行计划,找到优化sql性能的思路或方案. 如果你对sql查询优化的理解或常识不是很深入,那么推荐几骗博 ...

  8. ASP.NET OWIN OAuth:refresh token的持久化

    在前一篇博文中,我们初步地了解了refresh token的用途——它是用于刷新access token的一种token,并且用简单的示例代码体验了一下获取refresh token并且用它刷新acc ...

  9. 如何部署Zabbix服务端

    部署环境 RHEL 6.7 Zabbix-server 2.2.14 安装zabbix官方源 # wget http://repo.zabbix.com/zabbix/2.2/rhel/6/x86_6 ...

  10. SQL连接

    SQL连接可以分为内连接.外连接.交叉连接. 数据库数据:             book表                                          stu表 1.内连接 ...