ECMAScriptJavaScript权威设计–JavaScript数组(简要学习笔记九)

1.数组的创始

如:

var a=[1.1,null,"a"];
var b=[1, ,3];    //中间的那个元素是undefined
var  c=[ , , ]   

这边c.length你是勿是当是3?

哈哈哈,长度应该是2.因为数组直接量的语法允许生可选的最终逗号。

ECMAScript 1

 

2.数组索引的旁类

a[-1.23]=true  
 //创建一个称呼吧-1.23底特性

a[“1000”]=0  
 //如果是字符串,它就易为数组的目

a[1.000]    //和a[1]相等

JavaScript中从不数组越界的定义,只会得到undefined值。

 

3.数组长度的超常规表现

a=[1,2,3,4];
a.length    //4
a.length=3    //现在a=[1,2,3]
a.length=0    //现在a=[];

安装length属性为一个小鱼当前长的非负整数时,当前数组中那些索引值大于或等于n的元素用从中删除

 

4.forEach()和连锁的造福措施使得数组拥有简单而有力的函数式编程风格。

如:

var data=[1,2,3,4,5]    
var sumOf=0;
data.forEach(function(x){    //把每个元素传递给此函数
    sumOf+=x*x;
})
sumOf    //55

 

5.JavaScript不支持真正的几近各数组,可以据此数组的数组来仿佛。

 

6.数组与其余JS对象同有toString()方法。

如:

[1,2,3].toString()    //生成'1,2,3'
["a","b","c"].toString()    //生成'a,b,c'

 

 

7.ECMAScript5概念了9独新的数组方法来遍历,映射,过滤,检测,简化和查找数组。

一:forEach

 

亚:marp()方法以调用的数组的每个元素传递给指定的函数,并赶回一个数组

如:

a=[1,2,3];
b=a.map(function(x){
    return x*x;
})
//b是[1,2,9]

 

三:filter()

 

四:every()和some()

every()用法:

a=[1,2,3];
a.every(function(x){
    x<10;
})
//返回true,所有值小于10

 

some()用法:

a=[1,11,12];
a.some(function(x){
    x<10;
})
//返回true,只要有一个小于10即可返回true

 

五:reduce()和reduceRight()

 

六:indexOf()和lastIndexOf()

 

8.字符串当做数组看待时,他们是只读的ECMAScript。

如push,sort等数组的方法会修改数组,他们当字符串上是无用的。而且使用这些措施来修改字符串会招致差:出错的时没提示。