`

研究javascript的数组

阅读更多
数组有四种定义的方式

使用构造函数:
var a = new Array();
var b = new Array(8);
var c = new Array("first", "second", "third");
或者数组直接量:
var d = ["first", "second", "third"];

属性

Array只有一个属性,就是length,length表示的是数组所占内存空间的数目,而不仅仅是数组中元素的个数,在刚才定义的数组中,b.length的值为8

<script>
var a = new Array("first", "second", "third")
a[48] = "12"
document.write(a.length)
//显示的结果是49
</script>
数组的length属性是可写的,这是一个非常有意思的属性,我们可以通过这种方法来截取数组

<script>
var a = new Array("first", "second", "third")
delete a[1]
document.write(a.length)
//显示的结果是3,说明即使删除也无法改变数组的长度
var a = new Array("first", "second", "third")
a.length = 1
document.write(a.length)
//显示的结果是1,说明只剩下一个元素了
</script>
方法

这里并没有包括IE和FF并不兼容的一些方法:
toString():把数组转换成一个字符串
toLocaleString():把数组转换成一个字符串
join():把数组转换成一个用符号连接的字符串
shift():将数组头部的一个元素移出
unshift():在数组的头部插入一个元素
pop():从数组尾部删除一个元素
push():把一个元素添加到数组的尾部
concat():给数组添加元素
slice():返回数组的部分
reverse():将数组反向排序
sort():对数组进行排序操作
splice():插入、删除或者替换一个数组元素

toString()方法,toLocaleString()方法的作用类似,FF下的作用是完全相同的,IE的话如果元素是字符串,会在“,”后面加上一个空格,如果元素是数字,会扩展到两位小数,两者都会改变字符串的length属性,所以考虑到兼容性,尽量不要使用toLocaleString()方法。

<script>
var a = new Array(1, 2, 3, [4, 5, [6, 7]])
var b = a.toString() //b为字符串形式的 "1, 2, 3, 4, 5, 6, 7"
var c = new Array(1, 2, 3, [4, 5, [6, 7]])
var d = c.toLocaleString() //d为字符串形式的 "1, 2, 3, 4, 5, 6, 7"
//toString()方法和toLocaleString()方法都可以拆解多维数组
</script>
join()方法将数组中的所有元素转换成字符串,然后连接起来,这刚好和String的split()方法是一个相反的操作。join()默认是使用“,”作为分隔符,当然你也可以在方法中指定分隔符

<script>
var a = new Array("first", "second", "third")
var s = a.join("...")
document.write(s)
//显示的结果是“first...second...third”
</script>
pop()方法可以从数组尾部删除若干个元素,push()方法把一个元素添加到数组的尾部,这两个方法刚好是两个相反的操作。两个都是对原来的数组进行操作,但是要注意push()方法返回的是新的数组的长度,而pop()方法则返回被删去的那个元素。

<script>
var a = new Array(1, 2, 3)
var b = a.push(4,5,[6,7]) //a为[1, 2, 3, 4, 5, [6, 7]]  b为6  注意push()方法不会帮你打开一个数组
var c = new Array(1, 2, 3, 4, "first")
var d = c.pop() //c为[1, 2, 3, 4]  d为字符串形式的"first"
</script>
shift()方法可以从数组头部删除一个元素,unshift()方法把若干元素添加到数组的头部,这两个方法刚好是两个相反的操作。两个都是对原来的数组进行操作,但是要注意unshift()方法返回的是新的数组的长度,而shift()方法则返回被删去的那个元素。

<script>
var a = new Array(1, 2, 3)
var b = a.unshift(4,5,[6,7]) //a为[4, 5, [6, 7], 1, 2, 3]  b为6  注意unshift()方法不会帮你打开一个数组,还有就是被插入数值的顺序
var c = new Array("first", 1, 2, 3, 4)
var d = c.shift() //c为[1, 2, 3, 4]  d为字符串形式的"first"
</script>
concat()方法可以返回一个在原有数组上增添了元素的数组,元素用“,”分隔,元素中如果有数组,将被展开并继续添加,但不支持多维数组形式的展开添加

<script>
var a = new Array("first", "second", "third")
s = a.concat("fourth",["fifth", "sixth"],["seventh", ["eighth", "ninth"]])
document.write(s[7])
//显示的结果是“eighth, ninth”,说明“eighth, ninth”是以数组的形式被添加了进去,此是s的值为["first", "second", "third", "fourth", "fifth", "sixth", "seventh", ["eighth", "ninth"]]
</script>
slice()方法返回数组的一个片断,或者说是子数组。slice()的参数表示字数组的始末位置,如果只有一个参数,就表示从该处开始一直取到最后,如果参数出现负数,则表示倒数的某个位置。

<script>
var a = new Array(1, 2, 3, 4, 5)
var b = a.slice(3)  //b为[4, 5]
var c = a.slice(-3) //c为[3, 4, 5]
var d = a.slice(1,-1) //d为[2, 3, 4]
var e = a.slice(-3,-1) //e为[3, 4]
</script>
reverse()方法将数组反向排序,他并不创建和返回一个新的数组,而是在原有的数组上进行操作

<script>
var a = new Array("first", "second", "third")
a.reverse()
document.write(a)
//显示的结果是“third,second,first”,这时候数组的顺序已经颠倒了
</script>
sort()方法的作用是对数组进行排序,这是一个非常奇特的方法,我不知道当初创作他的人是出于懒惰还是聪明,这是一个让我印象深刻的方法。
sort()方法的参数是一个有两个参数,并且有返回值的函数,如果返回的值大于零,则说明前一个参数比后一个参数大,等于零则相等,小于零说明前一个参数比后一个小,而相对小的那个参数将出现在排序的前列。
sort()方法直接在数组上进行操作,同时也返回值,但是两者似乎是等价的。sort()方法默认是用字母的顺序进行排序

<script>
var a = new Array(33, 4, 111, 543)
a.sort(way)
function way(x, y){
    if (x % 2 ==0) 
        return 1;
    if (x % 2 !=0)       
        return -1;
}
//排序的结果是使奇数在前偶数在后
</script>
splice()方法的作用是插入、删除或者替换一个数组元素,他不光会在原有的数组上进行修改,还会返回被处理掉的内容,因此这是一个功能强大,但是不容易使用的方法,splice()方法用前两个参数进行定位,余下的参数表示插入部分。

<script>
var a = new Array(1, 2, 3, 4, 5)
var b = a.splice(2) //a为[1, 2]  b为[3, 4, 5]
var c = new Array(1, 2, 3, 4, 5)
var d = c.splice(2,2) //c为[1, 2, 5]  d为[3, 4]
var e = new Array(1, 2, 3, 4, 5)
var f = f.splice(-4,2) //e为[1, 4, 5]  f为[2, 3]
var g = new Array(1, 2, 3, 4, 5)
var h = g.splice(-2,-2) //第二个参数表示长度,因此负数在此无效

var i = new Array(1, 2, 3, 4, 5)
var j = i.splice(2,2,"first","second","third") //i为[1, 2, "first", "second", "third", 5]  j为[3, 4]  后面部分会自动前后移动,以保持数组的连续性
var k = new Array(1, 2, 3, 4, 5)
var l = k.splice(2,2,["first","second"],"third") //k为[1, 2, ["first", "second"], "third", 5]  l为[3, 4]  splice()方法不会展开数组,只直接写入
</script>
分享到:
评论

相关推荐

    javascript中数组、对象

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

    【JavaScript源代码】JavaScript数组去重问题的深入研究.docx

    ### JavaScript数组去重技术深入研究 #### 前言 数组去重是在处理大量数据时经常遇到的问题之一。为了提高程序效率以及代码的可读性和维护性,掌握多种不同的数组去重方法至关重要。 #### 最初的方法:双层循环 ...

    challenge-javascript-08:Challenge-javascript-08-JavaScript数组过滤器

    Challenge-javascript-08-JavaScript数组过滤器 Los Arrays en Javascript soportan lafunción filter ,从头到尾评估数组,并从头到尾保持数组状态。 Usando lafunción filter用于研究Array上的buscar todos ...

    JavaScript对象与数组参考大全

    JavaScript数组拥有一系列内置方法,如`push()`(添加元素到末尾)、`pop()`(移除末尾元素)、`shift()`(移除首位元素)、`unshift()`(添加元素到首位)、`splice()`(插入/删除元素)、`slice()`(提取子数组)...

    arrayjs:Javascript 数组填充

    在深入学习Array.js之前,了解JavaScript数组的基本操作是必要的,例如`push()`(添加元素到末尾)、`pop()`(移除末尾元素)、`shift()`(移除首元素)、`unshift()`(添加元素到开头)、`splice()`(插入/删除元素...

    Javascript数组中push方法用法分析

    本文实例讲述了Javascript数组中push方法用法。分享给大家供大家参考,具体如下: 看下面代码: var o = { 1:'a' ,2:'b' ,length:2 ,push:Array.prototype.push }; o.push('c'); Q:o现在内部的值是什么样子? ...

    javascript中的对象和数组的应用技巧

    在JavaScript中,数组是按引用传递的,这意味着如果你将一个数组赋值给另一个变量,这两个变量实际上指向同一个内存位置。因此,修改其中一个变量会影响到另一个: ```javascript var x = [10, 9, 8]; var y = x; x...

    sd-js-array-two:阵列测试

    在"sd-js-array-two:阵列测试"这个项目中,我们很显然是在深入研究JavaScript数组的特性和操作方法。这个项目可能包含了对数组的各种操作和挑战,目的是提升开发者在实际开发中的技能。 首先,让我们来看看"数组"这...

    JavaScript 规范(适合深入研究JavaScript的朋友)

    深入研究JavaScript规范,有助于提升代码质量、可维护性和团队协作效率。以下是对"JavaScript 规范"这一主题的详尽解析。 1. **基础语法** - 变量声明:了解`var`、`let`和`const`的区别,以及如何正确使用它们来...

    Head First Javascript源码

    6. **函数式编程**:JavaScript支持函数式编程范式,如map、reduce、filter等函数可以用于数组操作,提供了一种更简洁、更可读的编程方式。 7. **面向对象编程**:JavaScript基于原型的面向对象特性允许你创建和...

    JavaScript前端开发程序设计教程(微课版)-教材代码.zip

    JavaScript作为Web开发的核心语言之一,是前端开发人员的必备技能。本教程的“JavaScript前端开发程序设计教程(微课版)...通过深入研究这些代码,你不仅可以巩固JavaScript知识,还能提高问题解决和代码调试的能力。

    javascript基础学习资料,简单的用javascript实现的代码

    在学习这些材料时,建议首先理解JavaScript的基础语法,然后通过`.html`文件中的表单验证示例进行实践,最后结合`.chm`文件中的特效例子深入研究如何用JavaScript操纵网页元素,提升用户体验。同时,不要忘记与实际...

    javascript指南和函数式编程

    3. **数组和集合**:学习JavaScript中的数组操作,如map、filter、reduce等高阶函数的运用,以及Set和Map等ES6新增集合类型的使用。 4. **函数**:理解闭包、作用域和this的关键概念,学习箭头函数的语法和特性。 5....

    Javascript代码混淆的检测和反混淆应用研究.pdf

    通过对当前主流Web前端应用代码的观察分析,得出目前Javascript代码混淆的常见方式可以分为七类:变量改名型、代码简化型、字符密文型、数组代劳型、代码干扰型等。这些类型的混淆方式对代码的可读性和可维护性产生...

    javascript源码大全(精)

    JavaScript的基础包括变量声明(var、let、const)、数据类型(如字符串、数字、布尔值、null、undefined、对象、数组、符号和BigInt)、操作符(赋值、比较、逻辑、算术等)以及流程控制(条件语句、循环结构、...

    javascript,实现数据结构和算法题.zip

    JavaScript数组支持动态大小调整,提供了丰富的内置方法如push、pop、shift、unshift等。 2. 对象:在JavaScript中,对象是键值对的集合,可以看作是一种关联数组。可以通过属性名(字符串)来存取数据,支持原型链...

    JavaScript经典代码收集

    JavaScript是一种广泛应用于网页和网络应用的脚本语言,它的强大在于能够...这个“JavaScript经典代码收集”可能涵盖了以上部分或全部知识点,通过研究这些代码片段,可以加深对JavaScript语言的理解,提高编程能力。

    JavaScript菜鸟学习教程

    JavaScript,一种广泛应用于Web开发的轻量级编程语言,是前端开发的核心技术之一。本教程专为初学者设计,旨在帮助...同时,"JavaScript深度剖析课件 北大.ZIP"可能包含北京大学的教学资料,深入研究将有助于深化理解。

    JavaScript 5.CHM

    JavaScript 5.CHM 是一本关于JavaScript 5版本的详尽语言参考指南,它以其CHM(Compiled Help Manual)格式提供,这种...通过深入研究这个文档,开发者可以对JavaScript有更深入的理解,并能熟练地应用于实际项目中。

Global site tag (gtag.js) - Google Analytics