1
、数组的创建
以下为引用的内容:
vararrayObj=newArray();
//
创建一个数组
vararrayObj=newArray([size]);
//
创建一个数组并指定长度,注意不是上限,是长度
vararrayObj=newArray([element0[,element1[,...[,elementN]]]]);
创建一个数组并赋值
|
要说明的是,虽然第二种方法创建数组指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为5
,仍然可以将元素存储在规定长度以外的,注意:这时长度会随之改变。
2
、数组的元素的访问
vartestGetArrValue=arrayObj[1];//
获取数组的元素值
arrayObj[1]="
这是新值";//
给数组元素赋予新的值
3
、数组元素的添加
arrayObj.push([item1[item2[...[itemN]]]]);//
将一个或多个新元素添加到数组结尾,并返回数组新长度
arrayObj.unshift([item1[item2[...[itemN]]]]);//
将一个或多个新元素添加到数组开始,数组中的元素自动后移,返回数组新长度
arrayObj.splice(insertPos,0,[item1[,item2[,...[,itemN]]]]);//
将一个或多个新元素插入到数组的指定位置,插入位置的元素自动后移,返回""
。
4
、数组元素的删除
arrayObj.pop();//
移除最后一个元素并返回该元素值
arrayObj.shift();//
移除最前一个元素并返回该元素值,数组中元素自动前移
arrayObj.splice(deletePos,deleteCount);//
删除从指定位置deletePos
开始的指定数量deleteCount
的元素,数组形式返回所移除的元素
5
、数组的截取和合并
arrayObj.slice(start,[end]);//
以数组的形式返回数组的一部分,注意不包括end
对应的元素,如果省略end
将复制start
之后的所有元素
arrayObj.concat([item1[,item2[,...[,itemN]]]]);//
将多个数组(也可以是字符串,或者是数组和字符串的混合)连接为一个数组,返回连接好的新的数组
6
、数组的拷贝
arrayObj.slice(0);//
返回数组的拷贝数组,注意是一个新的数组,不是指向
arrayObj.concat();//
返回数组的拷贝数组,注意是一个新的数组,不是指向
7
、数组元素的排序
arrayObj.reverse();//
反转元素(最前的排到最后、最后的排到最前),返回数组地址
arrayObj.sort();//
对数组元素排序,返回数组地址
8
、数组元素的字符串化
arrayObj.join(separator);//
返回字符串,这个字符串将数组的每一个元素值连接在一起,中间用separator
隔开。
toLocaleString
、toString
、valueOf
:可以看作是join
的特殊用法,不常用
二、数组对象的3
个属性
1
、length
属性
Length
属性表示数组的长度,即其中元素的个数。因为数组的索引总是由0
开始,所以一个数组的上下限分别是:0
和length-1
。和其他大
多数语言不同的是,JavaScript
数组的length
属性是可变的,这一点需要特别注意。当length
属性被设置得更大时,整个数组的状态事实上 不会发生变化,仅仅是length
属性变大;当length
属性被设置得比原来小时,则原先数组中索引大于或等于length
的元素的值全部被丢失。下面
是演示改变length
属性的例子:
vararr=[12,23,5,3,25,98,76,54,56,76];
//
定义了一个包含10
个数字的数组
alert(arr.length);//
显示数组的长度10
arr.length=12;//
增大数组的长度
alert(arr.length);//
显示数组的长度已经变为12
alert(arr[8]);//
显示第9
个元素的值,为56
arr.length=5;//
将数组的长度减少到5
,索引等于或超过5
的元素被丢弃
alert(arr[8]);//
显示第9
个元素已经变为"undefined"
arr.length=10;//
将数组长度恢复为10
alert(arr[8]);//
虽然长度被恢复为10
,但第9
个元素却无法收回,显示"undefined"
由 上面的代码我们可以清楚的看到length
属性的性质。但length
对象不仅可以显式的设置,它也有可能被隐式修改。JavaScript
中 可以使用一个未声明过的变量,同样,也可以使用一个未定义的数组元素(指索引超过或等于length
的元素),这时,length
属性的值将被设置为所使 用元素索引的值加1
。例如下面的代码:
vararr=[12,23,5,3,25,98,76,54,56,76];
alert(arr.length);
arr[15]=34;
alert(arr.length);
代 码中同样是先定义了一个包含10
个数字的数组,通过alert
语句可以看出其长度为10
。随后使用了索引为15
的元素,将其赋值为15
,即 arr[15]=34
,这时再用alert
语句输出数组的长度,得到的是16
。无论如何,对于习惯于强类型编程的开发人员来说,这是一个很令人惊讶的特 性。事实上,使用newArray()
形式创建的数组,其初始长度就是为0
,正是对其中未定义元素的操作,才使数组的长度发生变化。
由上面的介绍可以看到,length
属性是如此的神奇,利用它可以方便的增加或者减少数组的容量。因此对length
属性的深入了解,有助于在开发过程中灵活运用。
2
、prototype
属性
返回对象类型原型的引用。prototype
属性是object
共有的。
objectName.prototype
objectName
参数是object
对象的名称。
说明:用prototype
属性提供对象的类的一组基本功能。
对象的新实例“
继承”
赋予该对象原型的操作。
对于数组对象,以以下例子说明prototype
属性的用途。
给数组对象添加返回数组中最大元素值的方法。要完成这一点,声明一个函数,将它加入Array.prototype
,
并使用它。
以下为引用的内容:
functionarray_max()
{
vari,max=this[0];
for(i=1;i<this.length;i++)
{
if(max<this[i])
max=this[i];
}
returnmax;
}
Array.prototype.max=array_max;
varx=newArray(1,2,3,4,5,6);
vary=x.max();
|
该代码执行后,y
保存数组x
中的最大值,或说6
。
3
、constructor
属性
表示创建对象的函数。
object.constructor//object
是对象或函数的名称。
说明:constructor
属性是所有具有prototype
的对象的成员。它们包括除Global
和Math
对象以外的所有JScript
固有对象。constructor
属性保存了对构造特定对象实例的函数的引用。
例如:
x=newString("Hi");
if(x.constructor==String)//
进行处理(条件为真)。
或
functionMyFunc{
//
函数体。
}
y=newMyFunc;
if(y.constructor==MyFunc)//
进行处理(条件为真)。
对于数组来说:
y=newArray();
判断是否数组的方法
vararrayVar=[\"aaa\",\"bbb\",\"ccc\"];
varnonArrayVar={length:4,otherAttribute:\"attr\"};
document.write(arrayVar.constructor==Array);
document.write(\"<br/>\");
document.write(nonArrayVar.constructor==Array);
结果是true,false
关于数组转换
可以使用[].slice.call()
或者Array.prototype.slice.call()
,但是IE6,IE7
下对DOM
元素集合使用这个操作时会报错,其它浏览器(Firefox,Opera,Safari)
都正常
示例代码:
(function(){
//SupportedbyFirefox,IE6,IE7,Opera,Safari
varargArray=[].slice.call(arguments);//argumentsisnotanarray,
//[].slice.call()willmakeanewarraywitharguments
document.write(argArray.reverse().join(\"&\"));//result:www&2&1
document.write(\"<br/>\"); [Page]
//SupportedbyFirefox,IE6,IE7,Opera,Safari
vararrayLike={0:\"ccc\",1:1,2:\"eee\",3:8,length:4};//anobjectthatlookslikeanobject
vartrueArray=[].slice.call(arrayLike,2,arrayLike.length);//makeanewarraywitharrayLike
trueArray.push(\"2008-02-12\");
document.write(trueArray.join(\"|\"));//result:eee|8|2008-02-12
document.write(\"<br/>\");
//SupportedbyFirefox,Opera,Safari
varobj=document.createElement(\"ul\");
obj.innerHTML=’<li>AAAAAA</li><listyle=\"display:none;\">BBBBBB</li>
<li>CCCCCC</li><li>DDDDDD</li>’;
varnodeList=obj.getElementsByTagName(\"li\");//DOMElementcollections
document.write(nodeList.length+\"linodefound!<br/>\");
varnodeArray=[].slice.call(nodeList);//makeanewarraywithnodeList
for(vari=0;i<nodeArray.length;i++){
document.write(nodeArray[i].textContent||nodeArray[i].innerText);
document.write(\"$\");
}//result:AAAAAA$BBBBBB$CCCCCC$DDDDDD$
})(1,2,\"www\");
grep
、map
Perl
语言带出来的东西,jQuery
里面就用了自己的grep
和map
实现
grep
对数组的grep
操作,指类似这样的代码:
ArraynewArray=grep(condition,oldArray)
,这个操作将对oldArray
数组的每个元素进行遍历,如果当前处理元素符合条件condition
,则加入到返回数组中
jQuery
中的grep
类似这样:function(elems,callback)
,elems
是DOM
元素集合,callback
是实现selector
的一些表达式函数,如果callback
返回true
则表明当前处理的元素符合selector
表达式
map
与grep
不同的是,map
不进行条件判断,只是对数组中每个元素执行指定的操作,就是将一个循环过程进行改装 [Page]
喜欢动态语言风格的,可以给数组加个grep
和map
方法,例如:
Array.prototype.grep=function(condition,operation,inverse){
if(arguments.length<1)return[];
vartester;
if(typeofcondition==\"function\")tester=condition;
elseif(condition.constructor==RegExp)tester=function(e,i){returncondition.test(e);};
elseif(typeofcondition==\"string\")
try{
tester=eval(\"false||function(e,i){return\"+condition+\";}\");
}catch(e){
}
elsetester=function(e,i){returnfalse;};
if(!tester)return[];
varcommand;
if(typeofoperation==\"function\")command=operation;
elseif(typeofoperation==\"string\")
try{
command=eval(\"false||function(e,i){\"+operation+\";returne;}\");
}catch(e){
}
if(typeofcommand!=\"function\")command=function(e,i){returne;};
varresult=[],match,t;
for(vari=0;i<this.length;i++){
match=tester(this[i],i);
if(match)t=command(this[i],i);
if(match&&!inverse&&t!=null)t.constructor==Array?result.concat(t):result.push(t);
elseif(!match&&inverse)result.push(this[i]);
[Page]
}
returnresult;
};
Array.prototype.map=function(callback){
if(!callback||typeofcallback!=\"function\")returnthis;
for(vari=0;i<this.length;i++)callback(this[i],i);
returnthis;
};
使用示例:
varoldArray=[2,7,8,5,1,9,2,6,0];
varnewArray1=oldArray.grep(\"i%2==0\");//returnelementswithevenindex
varnewArray2=oldArray.grep(\"e%2==1\");//returnelementswithoddvalue
document.write(newArray1+\"<br/>\");//result:2,8,1,2,0
document.write(newArray2+\"<br/>\");//result:7,5,1,9
oldArray=[\"aa\",\"bbbb\",\"abcdefg\",\"ccccc\",\"111121111\",\"999999999\"];
varnewArray3=oldArray.grep(/(\\w)\\1{4,}/);
document.write(newArray3+\"<br/>\");//result:ccccc,999999999
典型jQuery
风格的代码:
varobj=document.createElement(\"ul\");
obj.innerHTML=’<li>AAAAAA</li><listyle=\"display:none;\">BBBBBB</li>
<li>CCCCCC</li><li>DDDDDD</li>’;
document.body.appendChild(obj);
window.setInterval(function(){
//makeanewaarraywithDOMElementcollection
varliList=obj.getElementsByTagName(\"li\");
varliArray=[];
for(vari=0;i<liList.length;i++)liArray.push(liList[i]);
//grepforarraysexample
liArray
.grep(’e.style[\"display\"]==\"none\"’,’e.style[\"display\"]=\"\";’,true)
.map(function(e,i){e.style[\"display\"]=\"none\";});
},1500);
分享到:
相关推荐
JavaScript splice 数组操作(删除,插入)JavaScript splice 数组操作(删除,插入)JavaScript splice 数组操作(删除,插入)JavaScript splice 数组操作(删除,插入)JavaScript splice 数组操作(删除,插入)...
这些方法可以帮助开发者更方便地操作数组,实现各种数据处理和计算任务。 多维数组 Javascript 也支持多维数组,例如: `var myArray = new Array();` `for (var i = 0; i ; i++) {` ` myArray[i] = new Array();...
如果数组为空,它将不执行任何操作并返回 `undefined`。这个方法会改变原数组的长度。 ```javascript let arr = [1, 2, 3, 4, 5]; arr.pop(); // 删除最后一个元素 5 console.log(arr); // 输出:[1, 2, 3, 4] ...
JavaScript数组支持多种操作方法,如`push`(在末尾添加元素)、`pop`(移除并返回末尾元素)、`shift`(移除并返回首位元素)、`unshift`(在首位添加元素)、`slice`(截取子数组)、`splice`(插入、删除或替换...
了解如何操作数组对于使用JavaScript进行编程开发是必不可少的。 数组的创建可以通过new Array()的方式来实现,也可以通过数组字面量的方式。例如,创建一个空数组可以使用`var arrayObj = new Array();`,也可以...
### JavaScript中数组常见操作技巧 #### 数组的创建与初始化 在JavaScript中,创建数组通常使用数组字面量 `[]`。这与使用 `new Array()` 不同,因为后者在某些情况下用于创建指定长度的数组,而数组字面量则更加...
资源名称:Javascript数组及其操作 WORD版内容简介:本文档主要讲述的是Javascript数组及其操作;希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看 资源太大,传百度网盘了,链接在附件中,有...
JavaScript 数组提供了多种方法来操作数组,包括 join()、reverse()、push()、pop()、shift()、unshift() 等方法。join() 方法可以将数组的元素连接成一个字符串。reverse() 方法可以颠倒数组元素的顺序。push() 和...
### JavaScript:数组与字符串操作教程 #### 一、变量与数据类型 在JavaScript中,变量是用来存储数据值的重要工具。由于JavaScript是一种弱类型语言,因此在声明变量时无需明确指定其类型,变量的类型会根据所赋...
以上介绍了六种常用的 JavaScript 数组处理方法,包括基本的遍历、FIFO 和 LIFO 操作、搜索、函数应用以及数组过滤等。这些方法可以帮助开发者更高效地操作数组数据结构。值得注意的是,ECMAScript 5 引入了许多实用...
JavaScript:数组与字符串操作教程.docx
### JavaScript 常用数组操作方法详解 #### 一、前言 在现代Web开发中,JavaScript 是一种不可或缺的语言,而数组则是JavaScript中最基础也是最常用的数据结构之一。数组允许我们存储一系列有序的数据项,这些数据...
6. 操作数组的方法: - `concat()`:连接两个或多个数组,并返回新的数组。 - `slice()`:提取数组的一部分,并返回新数组,原数组不变。 - `splice()`:向/从数组中添加/删除项目,然后返回被删除的项目。 - `...
JavaScript中的数组操作方法是编程中不可或缺的部分,它们提供了丰富的功能,帮助我们高效地处理和操作数据。以下是对标题和描述中提到的一些JavaScript数组操作方法的详细说明: 1. **concat()**: `concat()` ...
内容概要:本文全面阐述了 JavaScript 中数组和字符串这两种重要数据类型的常用操作,覆盖了数组和字符串的创建、初始化、基本操作、遍历和查找等方面的知识。对于每一种类型都深入探讨了相关内置方法的功能和实际...
JavaScript 和 jQuery 中的数组操作是编程中非常基础且重要的部分,尤其在处理数据集合时。在 JavaScript 中,数组是一种特殊的数据结构,可以存储各种类型的数据,包括整型、字符串、对象等。虽然 JavaScript 不...
在JavaScript中,数组对象和JSON(JavaScript Object Notation)是两种非常重要的数据结构,它们在处理和存储数据方面起着核心作用。这篇学习笔记将深入探讨这两种数据结构的特性和用法。 首先,我们来了解...
在JavaScript中,虽然原生提供了多种数组操作方法,但在某些场景下可能需要更加灵活的控制方式。以下是一个自定义的数组插入方法 `insert` 的实现: ```javascript Array.prototype.insert = function (vVal, nIdx)...
JavaScript数组操作函数是编程中非常基础且重要的部分,它们提供了对数组进行各种操作的方法,包括添加、删除、合并以及转换等。以下是对标题和描述中提及的数组操作函数的详细说明: 1. **push()**: `push()` 函数...