js 数组操作类库 常规方式2.简洁方式字面

1. 正则方式

const hobbys = new Array()
hobbys[0] = 'Basketball'
hobbys[1] = 'Badminton'
hobbys[2] = 'swimming'
console.log(hobbys)
// [ 'Basketball', 'Badminton', 'swimming' ]

2.简单方法

const hobbys = new Array('Basketball', 'Badminton','swimming')
console.log(hobbys)
// [ 'Basketball', 'Badminton', 'swimming' ]

3.文字

const hobbys = ['Basketball','Badminton','swimming']
console.log(hobbys)
// [ 'Basketball', 'Badminton', 'swimming' ]

数组对象方法1. forEach

forEach() 方法用于调用数组的每个元素,将元素传递给回调函数。没有返回值js 数组操作类库,本质上相当于一个for循环,对每个item执行function函数。原数组不会改变。

// currentValue:必需,当前元素 index:可选,当前元素的索引值 arr:可选,当前元素所属的数组对象。
array.forEach(function(currentValue, index, arr)) 

let array = ['a', 'b', 'c']
let func = (currentValue, index, arr) => {
currentValue += 's'  
console.log('currentValue:' + currentValue + ' index:' + index + ' arr:' + arr)
}
array.forEach(func)
console.log(array)
// 控制台输出:
// currentValue:as index:0 arr:a,b,c
// currentValue:bs index:1 arr:a,b,c
// currentValue:cs index:2 arr:a,b,c
// [ 'a', 'b', 'c' ]

2.地图

通过指定函数处理数组的每个元素,并返回处理后的数组。

map() 方法返回一个新数组,数组中的元素是原数组元素的调用函数处理后的值。该方法按原始数组元素顺序依次处理元素。原数组不会改变。

// currentValue:必须,当前元素的值  index:可选,当前元素的索引值 arr:可选,当前元素属于的数组对象
array.map(function(currentValue,index,arr))

let array = [1, 2, 3, 4, 5]
let result = array.map((item) => { 
return item += 5
})
console.log(array)
console.log(result)
// [ 1, 2, 3, 4, 5 ]
// [ 6, 7, 8, 9, 10 ]

3.连接

JavaScript 中的 concat() 方法用于连接两个或多个数组并返回结果。

// array1, array2, ..., arrayN 必需,该参数可以是具体的值,也可以是数组对象,可以是任意多个
array1.concat(array2,array3,...,arrayN)

const array1 = ['a', 'b', 'c']
const array2 = ['d', 'e', 'f']
const array3 = array1.concat(array2)
console.log(array3)
const array4 = array1.concat('123')
console.log(array4)
// [ 'a', 'b', 'c', 'd', 'e', 'f' ]
// [ 'a', 'b', 'c', '123' ]

4.推

Javascript数组中的push()方法用于在数组末尾添加一个或多个元素,并返回新的长度。

let fruits = ["Banana", "Orange", "Apple", "Mango"]
let length = fruits.push("Kiwi")
console.log(fruits)
console.log(length)
// [ 'Banana', 'Orange', 'Apple', 'Mango', 'Kiwi' ]
// 5

5.取消移位

unshift() 方法将一个或多个元素添加到数组的开头并返回新的长度。

let fruits = ["Banana", "Orange", "Apple", "Mango"]
let length = fruits.unshift("Lemon", "Pineapple")
console.log(fruits)
console.log(length)
// [ 'Lemon', 'Pineapple', 'Banana', 'Orange', 'Apple', 'Mango' ]
// 6

6.弹出

pop() 方法用于移除数组的最后一个元素,并返回移除的元素。

let sites = ['Google', 'Runoob', 'Taobao', 'Zhihu', 'Baidu']
let result = sites.pop()
console.log(sites)
console.log(result)
// [ 'Google', 'Runoob', 'Taobao', 'Zhihu' ]
// Baidu

7.班次

shift() 方法用于从中移除数组的第一个元素并返回第一个元素的值

let fruits = ["Banana", "Orange", "Apple", "Mango"];
let result = fruits.shift()
console.log(fruits)
console.log(result)
// [ 'Orange', 'Apple', 'Mango' ]

// Banana

8.拼接

splice() 方法用于在数组中添加或删除元素,并返回已删除元素的数组

// 参数 Values: index: 必需,规定从何处添加/删除元素
// howmany: 可选,规定应该删除多少元素 必须是数字,但可以是 "0"
// item1, ..., itemX 可选,要添加到数组的新元素
array.splice(index,howmany,item1,.....,itemX)

let fruits = ["Banana", "Orange", "Apple", "Mango"]
let result = fruits.splice(1, 2, "Lemon", "Kiwi")
console.log(fruits)
console.log(result)
// [ 'Banana', 'Lemon', 'Kiwi', 'Mango' ]
// [ 'Orange', 'Apple' ]

9.切片

slice() 方法从现有数组中返回选定的元素。也可以提取字符串的一部分并将提取的部分作为新字符串返回。原数组不会改变。

// start: 可选,规定从何处开始选取 若为负值,表示从原数组中的倒数第几个元素开始提取
// end: 可选,规定从何处结束选取 如果没有指定该参数,那么切分的数组包含从start到数组结束的所有元素
array.slice(start, end)

let fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"]
let result1 = fruits.slice(1, 3)
let result2 = fruits.slice(2)
console.log(fruits)
console.log(result1)
console.log(result2)
// [ 'Banana', 'Orange', 'Lemon', 'Apple', 'Mango' ]
// [ 'Orange', 'Lemon' ]
// [ 'Lemon', 'Apple', 'Mango' ]

10.加入

join() 方法将所有数组元素连接成一个字符串。它的行为类似于 toString(),但你也可以指定分隔符

// separator: 可选,指定要使用的分隔符 如果省略该参数,则使用逗号作为分隔符
array.join(separator)  

let fruits = ["Banana", "Orange", "Apple", "Mango"];
let energy1 = fruits.join();
let energy2 = fruits.join('-');
console.log(energy1)
console.log(energy2)
// Banana,Orange,Apple,Mango
// Banana-Orange-Apple-Mango

11.每个

every() 方法用于检查数组的所有元素是否满足指定条件(由函数提供)。

array.every(function(currentValue,index,arr))

let ages = [32, 33, 16, 40]
let nums = [32, 33, 19, 40]
function checkAdult(age) {
return age >= 18
}
function checkNums(num) {
return num >= 18
}
// 16不满足大于18,故结果false
let result1 = ages.every(checkAdult)
// 每一项都满足条件,故结果true
let result2 = nums.every(checkNums)
console.log(result1)
console.log(result2)
// false
// true

12. 过滤器

filter() 方法创建一个新数组,通过检查指定数组中满足条件的所有元素来检查其元素。原数组不会改变。

array.filter(function(currentValue,index,arr), thisValue)

let ages = [32, 33, 16, 40];
function checkAdult(age) {
return age >= 18;
}
let result = ages.filter(checkAdult)
console.log(result)
// [ 32, 33, 40 ]

13.indexOf

indexOf() 方法返回字符串中指定字符串值的第一次出现。如果没有找到则返回 -1

// searchvalue: 必需。规定需检索的字符串值。
// start: 可选的整数参数。规定在字符串中开始检索的位置。值:0~array.length-1
string.indexOf(searchvalue,start)

let str = "Hello world, welcome to the universe.";
// 输出w所在的下标索引13(空格也算),没有找到会返回-1
let n = str.indexOf("welcome");
console.log(n)
console.log(str[n])
// 13
// w

14.减少

reduce() 方法接受一个函数作为累加器,数组中的每个值(从左到右)开始归约,最后计算为单个值。

array.reduce(function(total, currentValue, currentIndex, arr), initialValue)

let numbers = [2, 3, 5, 6]

function getSum(total, num) {
return total + num
}
let result = numbers.reduce(getSum, 0)
console.log(result)
// 16

15.反向

reverse() 方法用于反转数组中元素的顺序。将改变原始数组并返回重新排序的数组。

let fruits = ["Banana", "Orange", "Apple", "Mango"]
let resut = fruits.reverse()
console.log(fruits)
console.log(resut)
// [ 'Mango', 'Apple', 'Orange', 'Banana' ]
// [ 'Mango', 'Apple', 'Orange', 'Banana' ]

16.排序

sort() 方法用于对数组的元素进行排序。排序顺序可以是字母数字,也可以是升序或降序。

// sortfunction: 可选。规定排序顺序。必须是函数。
array.sort(sortfunction)

let fruits = ["Banana", "Orange", "Apple", "Mango"]
let ages = [9, 3, 4, 5, 7, 10]
// 升序
let agesFunAsc = function (ag1,ag2) {
return ag1 - ag2
}
// 降序
let agesFunDes= function (ag1,ag2) {
return -(ag1 - ag2)
}
fruits.sort()
ages.sort(agesFunAsc)
console.log(fruits)
console.log(ages)
ages.sort(agesFunDes)
console.log(ages)
// [ 'Apple', 'Banana', 'Mango', 'Orange' ]
// [ 3, 4, 5, 7, 9, 10 ]
// [ 10, 9, 7, 5, 4, 3 ]

17.toString

toString() 方法用于将数字转换为字符串。

number.toString(radix)

let num = 15
let n = num.toString()
// 也可以使用不同的进制把一个数字转换为字符串
// 2进制
let b = num.toString(2);

// 8进制
let c = num.toString(8);
// 16进制
let d = num.toString(16);
console.log(n)
console.log(b)
console.log(c)
console.log(d)
// 15
// 1111
// 17
// f

18. 在

at() 方法接受一个整数值并返回 at 索引的值,包括正整数和负整数。负整数从数组中的最后一项开始倒数。

array.at(index)

let str = 'helso word'
let item1 = str.at(2)
let item2 = str.at(-1)
console.log(item1)
console.log(item2)
// l
// d

19.找到

find() 方法返回通过测试的数组第一个元素的值(函数内判断)。

array.find(function(currentValue, index, arr),thisValue)

let ages = [3, 10, 18, 20];
function checkAdult(age) {
return age >= 18;
}
let value = ages.find(checkAdult)
console.log(value)
// 18

20.一些

some() 方法用于检查数组中的元素是否满足指定条件(由函数提供)。

array.some(function(currentValue,index,arr),thisValue)

let ages = [3, 10, 19, 20];
function checkAdult(age) {
return age > 18;
}
let result = ages.some(checkAdult)
console.log(result)
// true

20种常见的JavaScript数组操作总结文章到此为止。更多相关JavaScript数组操作js 数组操作类库,请搜索编程宝库以前的文章,希望以后多多支持编程宝库!

下一节:vueElementUI级联选择器回显问题解决JS编程技术

1. 分析问题【问题描述】使用ElementUI的Cascader级联选择器组件,如果使用数据的延迟加载和动态加载,v-model中的数据会被放回Cascad..。

© 版权声明
THE END
喜欢就支持一下吧
点赞268赞赏 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容