昨天学习了js的对象,了解了js的原型链。在js里面万事万物皆对象,只不过一些原始类型要经过包装对象的包装才能暂时变为对象。数组的本质是什么呢?数组其实就是一组数,也就是链表。每个数只是这个链表上的一个位置。js的对象属性值可以是字符串,但是js的数组对象的属性值只能是数字。经常称为索引(index)。在使用的时候可以把数组当成对象来使用。
1、创建数组的方式
正如茴香豆的茴有六种写法,我们的js对象也有三种的创建方式。如果你看过昨天的博客就会,了解到创建对象的三种方式。
-
对象直接量
<script> var arr = ['jack','rose','suse']; <script>
-
使用包装对象
<script> var arr = new Array('jack','rose','suse'); </script>
-
使用对象原型创建
<script> var arr = Array.create() </script>
2、稀疏数组与稠密数组
- 稀疏数组
稀疏数组就是指数组的索引(index),稀疏数组的索引并不是连续的,而是跳跃的,形如下面的代码。
<script>
var test = ['name',,'jack','suse'];
console.dir(test);
</script>
-
稠密数组
就是数组的索引是连续的,实际上我们平时使用的数组差不多都是稠密数组,在数组的使用上与稀疏数组并没有什么分别。
3、数组的遍历
数组的遍历还是使用for循环的比较多一点。我之前还使用过for in循环,不过for in循环用在对象里面更多一点。
4、数组的方法
- push
- unshift
- pop
- shift
- join
- reverse
- sort
- concat
- slice
- splice
- toString
- map
- filter
- every
- some
- reduce
以下为上面数组方法的例子,有兴趣的可以对照着看一下,最好是自己坐下demo,才能记得住。
<script>
//push 用来在数组尾部最后一位插入元素
var arr = ['rover','jack','rose','suse'];
arr.push('javascript');
console.dir(arr);
//unshift 在数组的头部插入一个元素
arr.unshift('first');
console.dir(arr);
//shift 删除数组头部的第一个元素。
arr.shift();
console.dir(arr);
//pop 删除数组尾部的最后一个元素
arr.pop();
console.dir(arr);
//reverse 返回一个逆序的数组。
//reverse并不返回一个新的数组,而是直接在原数组上修改。
var arrReverse = [1,2,3,4,5,6];
arrReverse.reverse();
console.dir(arrReverse);
//sort 排序函数
//当sort没有参数的时候,默认是按照英文字母来排序的。
//如果数组里面是一组数,则需要传入排序的函数。
var str = ['cup','apple','dog','banana'];
str.sort();
console.dir(str);
var num = [45.6,13.99,47.66,32,99,77]; //这里会先把数字转换成字母表顺序。
num.sort(function(a,b){
return a-b
});
console.dir(num);
//join 把数组切割成字符串,
var res = str.join('|');
console.dir(res);
//concat 相当于php里面array_merge函数了,拼合两个数组。
//不能去重,有点麻烦。
var arr1 = ['apple','banana'];
var arr2 = ['cat','dog'];
res = arr1.concat(arr2);
console.dir(res);
res.concat(['dog','fly']);
res.concat(['dog','fly']);
console.dir(res);
//slice 不包括最后一位。
var tmparr = ['apple','banana','cat','dog'];
res = tmparr.slice(0,1);
console.dir(res);
res = tmparr.slice(0,2);
console.dir(res);
console.dir(tmparr);
//splice
var sparr = ['apple','banana','cat','dog','eyy','fly','guy'];
msg = sparr.splice(1);
console.dir(msg);
console.dir(sparr);
//从以上两个打印的信息来看,splice是会在原来的数组进行处理的,会截取原数组的值。
//如果只有一个参数,则是从数组的该索引处开始往后截取。
var sparr1 = ['apple','banana','cat','dog','eyy','fly','guy'];
//第一个参数为从索引为1处开始截取,第二个参数为一共截取几个。
msg = sparr1.splice(1,2); //
console.dir(msg);
var sparr2 = ['apple','banana','cat','dog','eyy','fly','guy'];
msg = sparr2.splice(1,2,'香蕉','猫猫');
console.dir(msg);
console.dir(sparr2); //如果有第三个参数,则后续的参数为插入参数
//map 这个会对数组中的每一个值应用函数。
var marr = [1,2,3,4];
msg = marr.map(function(a){return a+1;});
console.dir(marr);
console.dir(msg);
//every 只有数组中所有的元素都满足条件,才返回true
var earr = [1,2,3,4];
msg = earr.every(
function(a){
return a > 3;
});
console.dir(msg);
//some 只要数组中有元素能满足条件就返回true
var somearr = [1,2,3,4];
msg = somearr.some(function(a){
return a > 3;
});
console.dir(msg);
//reduce 使用指定的函数将数组元素折叠
var rarr = [1,2,3,4];
msg = rarr.reduce(function(x,y){
return x+y;
});
console.dir(msg);
var rarr1 = [1,2,3,4];
msg = rarr1.reduce(function(x,y){
return (x>y)?x:y;
})
console.dir(msg);
</script>
5、数组判断
用这个方法还是比较准确的。
<script>
msg1 = Array.isArray([1,2]);
msg2 = Array.isArray({name:'jack'});
console.dir(msg1);
console.dir(msg2);
</script>