js数组常见使用整理

数组是js中最常见的数据结构,同时js的数组功能十分强大,本次整理经常使用的一些数组方法,同时实现两个简单的功能。

常见方法

使用两个简单数组:

var arr1 = ['a', 'b', 'c', 'b'];
var arr2 = ['x', 'y', 'z'];
1、Array.isArray()

判断一个变量是否为数组。

console.log(Array.isArray(arr1)); //true
2、concat()

数组合并,返回一个新数组。

console.log(arr1.concat(arr2));  //['a','b','c','b','x','y','z']
3、every()

判断数组中每个元素是否都满足条件。

var everyResult = arr1.every(function (value, index, array) {
    return value.length === 1;
});
console.log(everyResult); //true
4、filter()

获取数组中满足条件的元素,并返回一个新数组。

var filterResult = arr1.filter(function (value, index, array) {
    return value !== 'b';
});
console.log(filterResult);//['a','c']
5、forEach()

数组循环。

arr1.forEach(function (value) {
    console.log(value);  //a、b、c、b
});
6、indexOf()

获取元素所在数组位置(正向)

console.log(arr1.indexOf('a')); //0
7、join()

将数组元素使用某种内容分割,并拼接成一个字符串。

console.log(arr1.join(',')); //a,b,c,b
8、lastIndexOf()

获取元素所在数组位置(反向)

console.log(arr1.lastIndexOf('m')); //-1
9、map()

对数组中每个元素按某一方法进行处理,并返回一个新数组

var mapResult = arr1.map(function (value) {
    return value + value;
});
console.log(mapResult); //['aa','bb','cc','bb']
10、pop()

删除数组中最后一个元素并返回。

var popResult = arr1.pop();
console.log(popResult); //'b'
console.log(arr1); //['a','b','c']
11、push()

在数组末尾添加一个元素,返回数组长度。

var pushResult = arr1.push('d');
console.log(pushResult);  //4
console.log(arr1); //['a','b','c','d']
12、reverse()

数组倒序排列。

arr1.reverse();
console.log(arr1); //['d','c','b','a']
13、shift()

删除数组的第一个元素。

var shiftResult = arr1.shift();
console.log(shiftResult); //d
console.log(arr1); //['c','b','a']
14、slice()

复制一个元素,可以选择数组起始位置。

var sliceResult = arr1.slice(1,3);
console.log(sliceResult); //['b','a']
15、some()

判断数组中是否有一个元素满足条件。

var someResult = arr1.some(function (value) {
       return value === 'c';
});
console.log(someResult);  //true
16、sort()

数组排序方法。默认排序顺序是根据字符串Unicode值。

var sortResult = [1,2,3,10,20,25].sort();
console.log(sortResult); //[1,10,2,20,25,3]
17、splice()

从数组中的某个位置删除或者添加元素。

var spliceResult = arr1.splice(1,1,'e','f','g');
console.log(spliceResult); //b
console.log(arr1); //['c','e','f','g','a']
18、unshift()

在数组起始位置添加一个元素。

var unshiftResult = arr1.unshift('m');
console.log(unshiftResult); //6
console.log(arr1); //['m','c','e','f','g','a']

二、数组去重处理

1、利用set和…
var arr3 = ['a','b','c','a','d','b'];
var newArray = new Set(arr3);
console.log([...newArray]); //["a", "b", "c", "d"]
2、利用filter
var arr3 = ['a','b','c','a','d','b'];
var newArray = arr3.filter(function (value,index,array) {
    return index === array.indexOf(value);
});
console.log(newArray); //["a", "b", "c", "d"]

三、数组排序

1、利用sort方法
var arr4 = [1,5,3,7,8,4,6];
var newArray = arr4.sort(function (a,b) {
    return a-b;
});
console.log(newArray); //[1, 3, 4, 5, 6, 7, 8]

over…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在编程中,对象和数组的深拷贝涉及到数据结构的副本创建,确保新创建的对象与原对象独立,即使原对象发生改变也不会影响副本。这里有几种常见的深拷贝方式: 1. **浅拷贝(Shallow Copy)**: 对于简单类型(如基本数据类型)或值类型,拷贝的是它们的值。对于复杂类型如数组或对象,浅拷贝实际上是创建了一个引用,两个变量指向的是同一个内存地址。这意味着对其中一个的修改会影响到另一个。 2. **深拷贝(Deep Copy)**: - **复制数组**:对于数组,可以逐个元素地进行深拷贝,创建一个新的数组并填充每个元素的深拷贝。例如,在JavaScript中可以使用`JSON.parse(JSON.stringify(array))`来实现。 - **复制对象**: a. 使用构造函数:创建新对象,然后递归遍历原对象,为每个属性创建新的值,而不是引用。例如在JavaScript中,`function deepCopy(obj) { return new obj.constructor(obj); }`。 b. 使用`Object.assign()`和扩展运算符...:结合使用,创建一个新的对象,并将所有属性从源对象复制过来,但不会创建循环引用。但是这种方法不适用于原型链中的对象。 c. 库方法:有些编程语言有现成的库函数或模块可以直接完成深拷贝操作,比如Python的`copy.deepcopy()`。 3. **深度克隆(Deep Cloning)**: 术语"深度克隆"通常用于描述深度复制的过程,特别是在讨论复杂的数据结构,如树、图或对象树时。 **相关问题**: 1. 浅拷贝和深拷贝的主要区别是什么? 2. 如何在JavaScript中避免对象属性的引用冲突进行深拷贝? 3. 如果数组中的元素是对象,应该如何正确地进行深拷贝?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值