---恢复内容开始---

创建数组

1,通过

var arr1 = [1,2,3]

2通过使用

 var arr2 = new Array(1,2,3)

在这里创造的数组实际上都是一个对象,然后把对象的引用赋值给变量,实质上我们对数组的操作都是对引用进行操作。

读写数组

// 读取数组
var arr1 = [1,2,3,4];
for(var i = 0; i < arr1.length; i++) {
console.log(arr1[i]);
}
// 改变数组值
var arr2 = [];
for(var i = 0; i < 10; i++) {
arr2[i] = i;
}

我们可以用[]读取到索引的数组,同时也可以对他进行赋值改变的操作

由字符串生成数组

可以调用字符串对象的 split() 方法通过一个字符串生成一个数组。

var sentence = 'hello world haha hahahha';
var words = sentence.split(' ');
console.log(words);
// ["hello", "world", "haha", "hahahha"]

我们用空格号来切分了sentence这个字符串。

对数组进行整体性操作

把一个数组赋给另一个数组。

var arr1 = [1,2,3,4];
var arr2 = arr1;

这里 arr2 等于 arr1 了,但是别忘了,在 javascript 里面数组是一个对象,所以赋值的只是一个新的引用!如果我们修改了 arr2 会怎么样呢?

var arr1 = [1,2,3,4];
var arr2 = arr1;
arr2[4] = 5;
console.log(arr1);
// [1, 2, 3, 4, 5]

看见没有,arr2 改变了 arr1 也改变了,他们都是指向同一个数组对象,这种复制叫做浅复制。
现在我们有一个更好的方案-深复制:

function copyArr(arr) {
var _arr = [];
for(var i = 0; i < arr.length; i++) {
_arr[i] = arr[i];
}
return _arr;
}
var arr0 = [1,2,3,4];
var arr1 = copyArr(arr0);
console.log(arr1);
// [1, 2, 3, 4]
arr1[4] = 5;
console.log(arr0);
// [1, 2, 3, 4]
console.log(arr1);
// [1, 2, 3, 4, 5]

可以看到我们用循环遍历把 arr0 的元素复制给 arr1 的对应索引量的元素,改变 arr1,arr0 不改变。
当然这还是存在一些问题,比如这是个二维数组呢?数组嵌套再嵌套数组呢?可以在for循环里面判断元素是否数组,然后递归。

存取函数

查找元素

indexOf()是最常用的了,他接受一个参数,然后查找数组中元素等于这个参数值的第一个元素,返回对应的索引值,如果没有找到这个参数,返回-1,如果由多个,返回第一个的索引值。

var arr = [1,2,3,4,3,5];
console.log( arr.indexOf(2) );
//
console.log( arr.indexOf(6) );
// -1
console.log( arr.indexOf(3) );
//

还有一个对应的函数是lastIndexOf()他是从后面查找起的,对于多个,会返回查找到的第一个的索引值。

var arr = [1,2,3,4,3,5];
console.log( arr.lastIndexOf(2) );
//
console.log( arr.lastIndexOf(6) );
// -1
console.log( arr.lastIndexOf(3) );
//

数组的字符串表示

把数组转换成一个字符串有两个方法:toString() 和join()前者是生成用,分割开每个元素的字符串,后者可以传入一个参数来指导用这个参数值来隔开,上代码:

var arr = ['a', 'b', 'c'];
console.log( arr.toString() ); // a,b,c
console.log( arr.join('-') ); // a-b-c

由已有的数组创建新数组

方法有 concat()splice()slice()

  • concat() 接受多个数组作为参数,返回和他们合并的一个数组;
  • splice()截取一个数组的子集返回一个新数组;(会改变原数组)
  • slice()截取一个数组的子集:
  • var arr1 = [1,2,3,4];
    var arr2 = [5,6];
    var arr3 = [8];
    var arr4 = arr1.concat(arr2, arr3);
    console.log(arr4);
    // [1, 2, 3, 4, 5, 6, 8]
var arr1 = [1,2,3,4,5,6,7,8];
var arr2 = arr1.splice(2, 4); // 第一个参数是截取位置开始的索引值,第二个是截取的长度
console.log(arr2);
// [3, 4, 5, 6]
var arr3 = [1,2,3,4];
var arr4 = arr3.slice(1,3);
// [2, 3]

可变函数

为数组增减元素

添加

  • push()将一个元素添加到数组的末尾,返回被添加的元素;
  • unshift()将一个元素添加到数组开头,返回被添加的元素;
var arr = [1,2,3,4];
arr.push(5); //
console.log(arr);
// [1, 2, 3, 4, 5]
arr.unshift(0); //
console.log(arr);
// [0, 1, 2, 3, 4, 5]

删除

  • pop()删除数组末尾的一个元素,返回这个元素值;
  • shift()删除数组开头的一个元素,返回这个元素值;
var arr = [1,2,3,4];
arr.pop(); //
console.log(arr);
// [1, 2, 3]
arr.shift(); //
console.log(arr);
// [2, 3]

在数组中间添加或者删除元素
还是 splice方法,他接受参数:

  • 启始索引
  • 需要删除的数组个数(添加元素的时候可以是0)

需要添加进数组的元素

// 添加
var arr1 = [1,2,3,4,5];
arr1.splice(2, 0, 10);
console.log(arr1);
// [1, 2, 10, 3, 4, 5]
// 删除
var arr2 = [1,2,3,4,5];
arr2.splice(2, 1);
console.log(arr2);
// [1, 2, 4, 5]

为数组排序

  • reverse()可以使数组反转;
  • sort()排序,可以接受一个排序规则函数作为参数;
var arr = [1,2,3,4];
arr.reverse();
console.log(arr);
// [4, 3, 2, 1]
var arr = [23, 11, 8, 24, 55, 43];
arr.sort(function(a1, a2) {
return a1 - a2;
});
// [8, 11, 23, 24, 43, 55]

迭代方法

不生成新的数组的迭代器方法

forEach(),他接受一个函数作为参数,函数接受两个参数:当前元素值、当前元素索引,单纯遍历数组:

var arr = [10,20,30,40,50,60];
arr.forEach(function(item, idx) {
console.log(item);
console.log(idx);
});

every()接受一个返回值为布尔类型的函数为参数,对数组中每个元素使用该函数,如果全都是返回true则该方法返回true,如果有一个以上返回false,那么该方法返回false

var arr = [1,2,3,4,5,6];
var b1 = arr.every(function(item, idx) {
return item >= 1;
});
console.log(b1); // true
var b2 = arr.every(function(item, idx) {
return item >= 2;
});
console.log(b2); // false

some()方法,其实和every()方法很像,顾名思义,如果返回的有一个结果是true则返回true,如果全是false,则返回false;

var arr = [1,2,3,4,5,7];
var b1 = arr.some(function(item, idx) {
return item > 5;
});
console.log(b1); // true
var b2 = arr.some(function(item, idx) {
return item > 8;
});
console.log(b2); // false

reduce()方法,他接受两个参数:一个函数、一个初始值(可不传),函数接受4个参数:之前一次遍历的返回值(第一次的话就是初始值)、当前元素值、当前元素索引、被遍历的数组,函数返回一个值。他会从一个累加之开始不断对后面的元素调用该函数;

var arr = [1,2,3,4,5,6];
var sum = arr.reduce(function(runningTotal, currentValue) {
return runningTotal + currentValue;
}, 10);
console.log(sum); //

reduceRight()方法,它其实和reduce()方法一样,区别是他是从数组的右边开始累加到左边的。

生成新数组的方法

map()方法接受一个函数,这个函数处理每一个元素并返回一个新的值,然后方法会返回这些值组成的一个新数组。

var arr = [1,2,3,4,5];
var arr2 = arr.map(function(item, idx) {
return item + idx;
});
console.log(arr2);
// [1, 3, 5, 7, 9]

filter()方法接受一个函数,函数返回一个布尔类型的值,最后方法返回的数组是被函数返回true的元素的集合,顾名思义,就是过滤。

var arr = [1,2,3,4,5,6,7,8];
var arr2 = arr.filter(function(item, idx) {
return item % 2 === 0;
});
console.log(arr2);
// [2, 4, 6, 8]

二维数组和多维数组

创建二维数组

二维数组类似于一种行和列组成的数据表格。
在javascript里面定义二维数组,可以扩展javascript的数组对象:

Array.matrix = function(numrows, numcols, initial) {
var arr = [];
for(var i = 0; i < numrows; i++) {
var colnums = [];
for(var j = 0; j < numcols; j++) {
colnums[j] = initial;
}
arr[i] = colnums;
}
return arr;
}
var nums = Array.matrix(3,4,9);

处理二维数组中的元素

var arrs = [[1,2,3], [33,44,55], [12,23,34], [999, 000, 666]];
var total = 0;
for(var row = 0; row < arrs.length; row++) {
for(var col = 0; col < arrs[row].length; col++) {
total += arrs[row][col];
}
}
console.log(total); //

是否改变原数组

1.不改变原有数组:

  • indexOf
  • lastIndexOf
  • toString
  • join
  • concat
  • slice
  • some
  • forEach
  • every
  • filter
  • map
  • reduce
  • reduceRight

2.改变数组:

  • splice
  • push
  • pop
  • shift
  • unshift
  • reverse
  • sort

es6 中的新特性

Array.from()

Array.from方法可以将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括ES6新增的数据结构Set和Map)。

下面是一个类似数组的对象,Array.from将它转为真正的数组。

let arrayLike = {
'0': 'a',
'1': 'b',
'2': 'c',
length: 3
};
// ES5的写法
var arr1 = [].slice.call(arrayLike); // ['a', 'b', 'c']
// ES6的写法
let arr2 = Array.from(arrayLike); // ['a', 'b', 'c']

Array.of()

Array.of方法用于将一组值,转换为数组。
这个方法的主要目的,是弥补数组构造函数Array()的不足。因为参数个数的不同,会导致Array()的行为有差异。
就是之前说的在用 new 构造一个数组的时候,如果传入的是一个数字,那么返回的是一个该长度的数组:

var arr0 = new Array(2);
console.log(arr0);
// []
arr0.length; //

如果使用 Array.of:

var arr0 = Array.of(2);
console.log(arr0);
// [2]
var arr1 = Array.of(1,2,3);
console.log(arr1);
// [1,2,3]

数组实例的copyWithin()

数组实例的copyWithin方法,在当前数组内部,将指定位置的成员复制到其他位置(会覆盖原有成员),然后返回当前数组。也就是说,使用这个方法,会修改当前数组。

它接受三个参数:

  • target(必需):从该位置开始替换数据。
  • start(可选):从该位置开始读取数据,默认为0。如果为负值,表示倒数。
  • end(可选):到该位置前停止读取数据,默认等于数组长度。如果为负值,表示倒数。
[1, 2, 3, 4, 5].copyWithin(0, 3)
// [4, 5, 3, 4, 5]

数组实例的find()和findIndex()

数组实例的find方法,用于找出第一个符合条件的数组成员。它的参数是一个回调函数,所有数组成员依次执行该回调函数,直到找出第一个返回值为true的成员,然后返回该成员。如果没有符合条件的成员,则返回undefined。

[1, 4, -5, 10].find((n) => n < 0)
// -5

数组实例的findIndex方法的用法与find方法非常类似,返回第一个符合条件的数组成员的位置,如果所有成员都不符合条件,则返回-1

[1, 4, -5, 10].find((n) => n < 0)
//

数组实例的fill()

fill方法使用给定值,填充一个数组。

['a', 'b', 'c'].fill(7)
// [7, 7, 7]
new Array(3).fill(7)
// [7, 7, 7]

fill方法还可以接受第二个和第三个参数,用于指定填充的起始位置和结束位置。

['a', 'b', 'c'].fill(7, 1, 2)
// ['a', 7, 'c']

数组实例的entries(),keys()和values()

ES6提供三个新的方法——entries(),keys()和values()——用于遍历数组。

for (let index of ['a', 'b'].keys()) {
console.log(index);
}
//
//
for (let elem of ['a', 'b'].values()) {
console.log(elem);
}
// 'a'
// 'b'
for (let [index, elem] of ['a', 'b'].entries()) {
console.log(index, elem);
}
// 0 "a"
// 1 "b"

数组实例的includes()

Array.prototype.includes方法返回一个布尔值,表示某个数组是否包含给定的值,与字符串的includes方法类似。该方法属于ES7,但Babel转码器已经支持。

[1, 2, 3].includes(2);     // true
[1, 2, 3].includes(4); // false
[1, 2, NaN].includes(NaN); // true

该方法的第二个参数表示搜索的起始位置,默认为0。如果第二个参数为负数,则表示倒数的位置,如果这时它大于数组长度(比如第二个参数为-4,但数组长度为3),则会重置为从0开始。

[1, 2, 3].includes(3, 3);  // false
[1, 2, 3].includes(3, -1); // true

转自https://qiutc.me/post/javascript-array.html

JavaScript中数组的使用的更多相关文章

  1. JavaScript中数组操作常用方法

    JavaScript中数组操作常用方法 1.检测数组 1)检测对象是否为数组,使用instanceof 操作符 if(value instanceof Array) { //对数组执行某些操作 } 2 ...

  2. javascript中数组Array的方法

    一.常用方法(push,pop,unshift,shift,join)push pop栈方法,后进先出var a =[1,2,3];console.log(a.push(40)); //4 返回数组的 ...

  3. Javascript中数组

    Javascript中数组 1.什么是数组 所谓的数组就是一组数据的集合,在内存中表现为一段连续的内存地址(保存在堆内存) 2.创建数组的含义 创建数组的目的:就是为了保存更多的数据 3.数组的定义 ...

  4. javascript中数组常用方法总结

    原文:javascript中数组常用方法总结 在javascript的基础编程中,数组是我们最常遇到的,那么数组的一些常用方法也是我们必须要掌握的,下面我们总结一下数组中常用的方法. toString ...

  5. JavaScript中数组Array方法详解

    ECMAScript 3在Array.prototype中定义了一些很有用的操作数组的函数,这意味着这些函数作为任何数组的方法都是可用的. 1.Array.join()方法 Array.join()方 ...

  6. javascript中数组的常用算法深入分析

    Array数组是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array是前端必修的功课.本文将给大家详细介绍了javascri ...

  7. javascript中数组化的一般见解

    javascript中数组化的一般见解,数组化浏览器中存在许多类数组对象,往往对类数组操作比较麻烦,没有数组那些非常方便的方法,在这种情况下,就有了数组化方法. 数组化的一般方法 1.第一种也是我们最 ...

  8. 总结Javascript中数组各种去重的方法

    相信大家都知道网上关于Javascript中数组去重的方法很多,这篇文章给大家总结Javascript中数组各种去重的方法,相信本文对大家学习和使用Javascript具有一定的参考借鉴价值,有需要的 ...

  9. JavaScript中数组常用方法的总结

    JavaScript中数组Array常用的方法总结 标签(空格分隔): JavaScript ECMAScript数组给我们提供了许多常用的方法,便于我们对数组进行操作,下面,就来总结一下这些方法. ...

  10. JavaScript中数组Array.sort()排序方法详解

    JavaScript中数组的sort()方法主要用于对数组的元素进行排序.其中,sort()方法有一个可选参数.但是,此参数必须是函数. 数组在调用sort()方法时,如果没有传参将按字母顺序(字符编 ...

随机推荐

  1. jsf+ejb

    jsf+ejb 示例 http://docs.jboss.org/jbossas/docs/Installation_And_Getting_Started_Guide/5/html/Sample_J ...

  2. ORA-01950:表空间“USERS”中无权限

    ORA-01950:表空间“USERS”中无权限 解决方案: A)确认给用户授权了resource角色 B)取消限制 ALTER USER "HCCPMS" QUOTA UNLIM ...

  3. 运用html常用标签和css定位等学做模仿百度导航页面

    导航部分文字链接,鼠标触碰变颜色,除百度logo引用图片外,其它均代码编写.注释部分是一开始用的百度一下截图做的按钮,后来用div填充颜色写了一个按钮.效果图如下. HTML代码如下: <!DO ...

  4. 架构sass文件

    sass/ | |– base/ | |– _reset.scss # Reset/normalize | |– _typography.scss # Typography rules | ... # ...

  5. 福昕阅读器把pdf某一页保存出来

    第一步: 第二步: 第三步: 第四步:点击保存即可

  6. codevs1026-dp(记忆化搜索)

    题目描述 Description 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置. 那个装置太旧了,以至于只能发射关于那辆车的移动 ...

  7. jQuery解决ajax请求的跨域问题

    这两天工作中频繁的遇到JS的跨域问题,都通过绕开ajax请求的方式.特地百度了一下,把跨域问题解决了.在这分析一下 首先贴上js的页面代码: <html> <head> < ...

  8. python 1 学习廖雪峰博客

    输出 用print()在括号中加上字符串,就可以向屏幕上输出指定的文字.比如输出'hello, world',用代码实现如下: >>> print('hello, world') p ...

  9. 使用cp命令拷贝目录下指定文件外的其他文件

    shopt -s extglob cp test/!(abc*) test2/ cp test目录下除了以abc开头的其他文件 如果是除去多个文件的话使用   !(a|b)   ;   注意不要多加空 ...

  10. Exception in thread "main" java.lang.UnsupportedClassVersionError: com/google/common/base/Function : Unsupported major.minor version 52.0的解决办法(图文详解)

    不多说,直接上干货! 问题详情 Exception in thread "main" java.lang.UnsupportedClassVersionError: com/goo ...