`
gift5168xf
  • 浏览: 29209 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Javascript操作数组

阅读更多

 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
toStringvalueOf :可以看作是join 的特殊用法,不常用
二、数组对象的3 个属性
1
length 属性
Length 属性表示数组的长度,即其中元素的个数。因为数组的索引总是由0 开始,所以一个数组的上下限分别是:0length-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 的对象的成员。它们包括除GlobalMath 对象以外的所有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 里面就用了自己的grepmap 实现
grep
对数组的grep 操作,指类似这样的代码:
ArraynewArray=grep(condition,oldArray)
,这个操作将对oldArray 数组的每个元素进行遍历,如果当前处理元素符合条件condition ,则加入到返回数组中
jQuery
中的grep 类似这样:function(elems,callback)elemsDOM 元素集合,callback 是实现selector 的一些表达式函数,如果callback 返回true 则表明当前处理的元素符合selector 表达式

map

grep 不同的是,map 不进行条件判断,只是对数组中每个元素执行指定的操作,就是将一个循环过程进行改装 [Page]

喜欢动态语言风格的,可以给数组加个grepmap 方法,例如:
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 splice 数组操作(删除,插入)...

    Javascript数组及其操作

    这些方法可以帮助开发者更方便地操作数组,实现各种数据处理和计算任务。 多维数组 Javascript 也支持多维数组,例如: `var myArray = new Array();` `for (var i = 0; i ; i++) {` ` myArray[i] = new Array();...

    JavaScript如何删除数组元素!

    如果数组为空,它将不执行任何操作并返回 `undefined`。这个方法会改变原数组的长度。 ```javascript let arr = [1, 2, 3, 4, 5]; arr.pop(); // 删除最后一个元素 5 console.log(arr); // 输出:[1, 2, 3, 4] ...

    javascript中数组、对象

    JavaScript数组支持多种操作方法,如`push`(在末尾添加元素)、`pop`(移除并返回末尾元素)、`shift`(移除并返回首位元素)、`unshift`(在首位添加元素)、`slice`(截取子数组)、`splice`(插入、删除或替换...

    javascript操作数组详解

    了解如何操作数组对于使用JavaScript进行编程开发是必不可少的。 数组的创建可以通过new Array()的方式来实现,也可以通过数组字面量的方式。例如,创建一个空数组可以使用`var arrayObj = new Array();`,也可以...

    JavaScript中数组常见操作技巧

    ### JavaScript中数组常见操作技巧 #### 数组的创建与初始化 在JavaScript中,创建数组通常使用数组字面量 `[]`。这与使用 `new Array()` 不同,因为后者在某些情况下用于创建指定长度的数组,而数组字面量则更加...

    Javascript数组及其操作WORD版

    资源名称:Javascript数组及其操作 WORD版内容简介:本文档主要讲述的是Javascript数组及其操作;希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看 资源太大,传百度网盘了,链接在附件中,有...

    JavaScript数组用法详解

    JavaScript 数组提供了多种方法来操作数组,包括 join()、reverse()、push()、pop()、shift()、unshift() 等方法。join() 方法可以将数组的元素连接成一个字符串。reverse() 方法可以颠倒数组元素的顺序。push() 和...

    JavaScript:数组与字符串操作教程

    ### JavaScript:数组与字符串操作教程 #### 一、变量与数据类型 在JavaScript中,变量是用来存储数据值的重要工具。由于JavaScript是一种弱类型语言,因此在声明变量时无需明确指定其类型,变量的类型会根据所赋...

    javascript循环数组有什么方法_javascript循环数组有哪些方法.docx

    以上介绍了六种常用的 JavaScript 数组处理方法,包括基本的遍历、FIFO 和 LIFO 操作、搜索、函数应用以及数组过滤等。这些方法可以帮助开发者更高效地操作数组数据结构。值得注意的是,ECMAScript 5 引入了许多实用...

    JavaScript:数组与字符串操作教程.docx

    JavaScript:数组与字符串操作教程.docx

    JavaScript常用数组操作方法.docx

    ### JavaScript 常用数组操作方法详解 #### 一、前言 在现代Web开发中,JavaScript 是一种不可或缺的语言,而数组则是JavaScript中最基础也是最常用的数据结构之一。数组允许我们存储一系列有序的数据项,这些数据...

    Javascript数组操作整理.rar

    6. 操作数组的方法: - `concat()`:连接两个或多个数组,并返回新的数组。 - `slice()`:提取数组的一部分,并返回新数组,原数组不变。 - `splice()`:向/从数组中添加/删除项目,然后返回被删除的项目。 - `...

    JavaScript常用数组操作方法1

    JavaScript中的数组操作方法是编程中不可或缺的部分,它们提供了丰富的功能,帮助我们高效地处理和操作数据。以下是对标题和描述中提到的一些JavaScript数组操作方法的详细说明: 1. **concat()**: `concat()` ...

    前端开发中JavaScript的数组与字符串操作详解及其应用

    内容概要:本文全面阐述了 JavaScript 中数组和字符串这两种重要数据类型的常用操作,覆盖了数组和字符串的创建、初始化、基本操作、遍历和查找等方面的知识。对于每一种类型都深入探讨了相关内置方法的功能和实际...

    JavaScript jQuery 中定义数组与操作及jquery数组操作

    JavaScript 和 jQuery 中的数组操作是编程中非常基础且重要的部分,尤其在处理数据集合时。在 JavaScript 中,数组是一种特殊的数据结构,可以存储各种类型的数据,包括整型、字符串、对象等。虽然 JavaScript 不...

    javascript中的数组对象以及json学习笔记

    在JavaScript中,数组对象和JSON(JavaScript Object Notation)是两种非常重要的数据结构,它们在处理和存储数据方面起着核心作用。这篇学习笔记将深入探讨这两种数据结构的特性和用法。 首先,我们来了解...

    JavaScript 数组 增加 和 删除

    在JavaScript中,虽然原生提供了多种数组操作方法,但在某些场景下可能需要更加灵活的控制方式。以下是一个自定义的数组插入方法 `insert` 的实现: ```javascript Array.prototype.insert = function (vVal, nIdx)...

    JavaScript数组操作函数汇总

    JavaScript数组操作函数是编程中非常基础且重要的部分,它们提供了对数组进行各种操作的方法,包括添加、删除、合并以及转换等。以下是对标题和描述中提及的数组操作函数的详细说明: 1. **push()**: `push()` 函数...

Global site tag (gtag.js) - Google Analytics