JS高程5.引用类型(4)Array类型的各类方法
一.转换方法
所有的对象都具有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类型的各类方法的更多相关文章
- JS_高程5.引用类型(4)Array类型的各类方法
一.转换方法 所有的对象都具有toLocaleString(),toString()和valueOf()方法.调用toString()方法会返回由数组中的每个值的字符串拼接而成的一个以逗号分隔的字符串 ...
- JS高程5.引用类型(3)Array类型-检测数组
1. instanceof操作符(ECMAScript3) 对于一个网页,或者是一个全局作用域而言,使用instanceof操作符来检测数组就可以得到满意的结果. 语法:if(value instan ...
- JS高程5.引用类型(2)Array类型
Array类型: ECMAScript数组的每一项可以保存任何类型的数据,数组的大小是可以动态调整的. 创建数组的基本方式: (1)使用Array构造函数 var color=new Array(); ...
- Js高程笔记->引用类型
1 . Object 对象 2 . Array 对象 : 检测方法:ES5 : isArray 转换方法: toLocaleString , toString , val ...
- 《JS高程》引用类型学习笔记
2月圆满的结束了,结束之前是如凤凰般的涅槃.一边上班,一边搞科研的忙碌有点让人透不过气,心会不由得浮躁起来.但是,无论什么事情,只要充满耐心.专心去做,总会朝好的方向发展,心态真的很重要.Anyway ...
- JavaScript引用类型之Array类型一
一.简介 除了Object之外,Array类型恐怕是ECMAScript中最常用的类型了.下面就来分析ECMAScript中的数组与其他语言中的数组的异同性: 1.相同点: (1)他们都是数据的有序列 ...
- JavaScript引用类型之Array类型API详解
Array类型也是ECMASCRIPT中最常见的数据类型,而且数据的每一项可以保存任何类型的数值,而且数组的大小是可以动态调整的,可以随着数据的添加自动增长以容纳新的数据.下面,总结数据的一些常用方法 ...
- 引用类型之Array类型
Array类型 ECMAScript数组与其它语言数组一样,都是数据的有序列表.但是ECMAScript数组的每一项可以保存任何类型的数据.而且,ECMAScript数组是可以动态调整的. 1.创建和 ...
- JavaScript之引用类型(Array类型)
除了Object类型,Array是ECMAScript中最常用的类型了. 与其他语言不同的是,ECMAScript数组的每一项可以保存任何类型的数据. 而且,ECMAScript数组的大小是可以动态调 ...
随机推荐
- linux常用命令(2)pwd命令
pwd 命令1 命令格式:pwd [选项]2 命令功能查看当前工作目录的完整路径3 常用参数一般不带任何参数如果目录是链接时:pwd -P 显示实际路径,而非使用链接路径4 常用实例:4.1 用pwd ...
- Merge Sorted Array
Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted array. Note:Yo ...
- 开始mono开发
使用mono框架开发android程序,第一步当然是构建开发环境,严格意义上说是使用 mono for android开发android程序. 参考Mono for Android安装配置破解 mo ...
- WPF - 属性系统 (3 of 4)
依赖项属性元数据 在前面的章节中,我们已经介绍了WPF依赖项属性元数据中的两个组成:CoerceValueCallback回调以及PropertyChangedCallback.而在本节中,我们将对其 ...
- Angular移除不必要的$watch之性能优化
双向绑定是Angular的核心概念之一,它给我们带来了思维方式的转变:不再是DOM驱动,而是以Model为核心,在View中写上声明式标签.然后,Angular就会在后台默默的同步View的变化到Mo ...
- SQL Server数据库损坏、检测以及简单的修复办法
简介 在一个理想的世界中,不会存在任何数据库的损坏,就像我们不会将一些严重意外情况列入我们生活中的日常一样,而一旦这类事情发生,一定会对我们的生活造成非常显著的影响,在SQL Server中也 ...
- 查看Windows下引起Oracle CPU占用率高的神器-qslice
前言: qslice是一个win2000的工具包,能分析进程的cpu占用率,我们用于分析oracle的性能 这是绿色的软件无需安装. 我们经常会碰到oracle的CPU占用居高不下,无法快速定位到问题 ...
- SQL统计
--按周统计SELECT TOP 10DATENAME(year,AddDate) 年,DATENAME(week,AddDate) 周,COUNT(1) 单量,SUM(total) 总金额,AVG( ...
- seajs的使用
写在前面 seajs是什么? Seajs是一个js文件加载器. 遵循 CMD 规范模块化开发,依赖的自动加载.配置的简洁清晰. 用于Web开发的模块加载工具,提供简单.极致的模块化体验 一:使用 文件 ...
- 高性能JavaScript--加载和执行(简要学习笔记一)
1.多数浏览器使用单一进程来处理用户界面刷新和JavaScript脚本的执行.所以同一时刻只能做同一件事.JavaScript执行过程耗时越久,浏览器等待相应的时间就越长. 2.<scrip ...