6个ES6中很酷的数组函数
1、Array .of
关于奇怪的 Array 函数,众所周知,我们可以通过Array函数做以下事情。
初始化指定长度的数组;设置数组的初始值。
// 1. Initialize an array of the specified length
const array1 = Array(3) // [ , , ]
// 2. Set the initial value of the array
const array2 = Array() // []
const array3 = Array(undefined) // [ undefined ]
const array4 = Array(1. 2. 3) // [ 1. 2. 3 ]
传递给Array函数的参数个数不一样,其作用也不一样。这常常让我感到困惑。
幸运的是,我们可以使用 Array.of 来弥补 Array 的不足。
// it's not initializing an array of length 3
const array1 = Array.of(3) // [ 3 ]
const array2 = Array.of() // []
const array3 = Array.of(undefined) // [ undefined ]
const array4 = Array.of(1. 2. 3) // [ 1. 2. 3 ]
2、 Array.from
from 方法中,我们可以通过 Array.from 方法将类数组对象、arguments 对象、NodeList 对象转换为真正的数组。
1)、类数组对象
const arrayLike = {
0: 'fatfish',
1: 'medium',
length: 2
}
const array1 = [].slice.call(arrayLike) // ['fatfish', 'medium']
// A more convenient way
const array2 = Array.from(arrayLike) // ['fatfish', 'medium']
2)、节点列表
const domsNodeList = document.querySelectorAll('div')
const domsArray = Array.from(domsNodeList) // [ dom, dom, dom, ... ]
3)、 Arguments
const logInfo = function () {
console.log('arguments', arguments)
console.log('Array.from arguments', Array.from(arguments))
}
logInfo('fatfish', 100)
logInfo('fatfish')
4)、Array.from的第二个参数
我们可以使用 Array.from 方法,如“[].map”。
const array = [ 1. 2. 3 ]
const array2 = array.map((num) => num * 2) // [2. 4. 6]
const array3 = Array.from(array, (num) => num * 2) // [2. 4. 6]
3、 includes
当满足其中一个条件时,我们经常会写这样的判断语句来做某事。
const num = 1
if (num === 1 || num === 2 || num === 3 || num === 4) {
console.log(num) // 1
}
其实可以通过include方法来简化代码。
const nums = [ 1. 2. 3. 4 ]
const num = 1
if (nums.includes(num)) {
console.log(num) // 1
}
4、使用“at方法”读取数组的尾部元素
你如何读取数组的尾部元素?是的,我们需要以“array.length-1”作为下标来读取。
const array = [ 1. 2. 3. 4. 5 ]
const lastEle = array[ array.length - 1 ] // 5
// You can't read like that
const lastEle = array[ - 1 ] // undefined
还有其他方法吗?
是的,“at”方法将成为您的魔法。当然,您也可以读取数组中其他位置的元素。
const array = [ 1. 2. 3. 4. 5 ]
const lastEle = array.at(-1) // 5
const ele1 = array.at(0) // 1
5、 flat
flat() 方法创建一个新数组,其中所有子数组元素递归连接到指定深度。
const array = [ 1. [ 2. [ 3. [ 4. [ 5 ] ] ] ] ]
// The default depth is 1
const flat1 = array.flat() // [ 1. 2. [ 3. [ 4. [ 5 ] ] ] ]
const flat2 = array.flat(2) // [ 1. 2. 3. [ 4. [ 5 ] ] ]
const flatAll = array.flat(Infinity) // [ 1. 2. 3. 4. 5 ]
6、 findIndex
“findIndex() 方法返回数组中满足提供的测试函数的第一个元素的索引。否则,它返回 -1.表示没有元素通过测试。”
const array = [ -1. 0. 10. 10. 20. 100 ]
const index1 = array.findIndex((num) => num < 0) // 0
const index2 = array.findIndex((num) => num >= 10) // 2
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
今日已有369人领取成功

相关推荐HOT
更多>>
自己小店售卖的商品除了自己账号带货,能不能让其他账号帮我推广卖货呢?
商家店铺体验分高于(含)4分,在小店后台找到营销窗口,进入精选联盟,选择需要推广的商品,建立推广计划(普通计划、定向计划、专属计划等)设置...详情>>
2022-11-28 17:06:07
为什么我上传产品提示审核不通过被驳回?
①是否提交完善相关(品牌资质、行业资质、授权资质、商品资质及其他相关各类证明材料)②检查商品标题是否有诱导词、极限词,以及产品功效夸大词...详情>>
2022-11-28 17:05:09
开通小店后首先要设置哪些选项,会有流量倾斜加持?
运费险:在商家保障中心中点进去勾选上,那前期做店铺起的时候一定要把运费险开通,后期你可以给它关掉,极速退:在前期起店急速退助手同样呢,...详情>>
2022-11-28 17:04:15
直播间怎样才能获得更多的直播推荐流量?
不同行业类目、不同粉丝数量基数、不同客单价的流量级别分配,直播的流量推荐逻辑根据,点击(曝光点击进入率、商品点击率),停留(观看时长),互...详情>>
2022-11-28 17:03:23热门推荐
自己小店售卖的商品除了自己账号带货,能不能让其他账号帮我推广卖货呢?
沸为什么我上传产品提示审核不通过被驳回?
热开通小店后首先要设置哪些选项,会有流量倾斜加持?
热直播间怎样才能获得更多的直播推荐流量?
新小店体验分越来越低,该如何提升分数?
为什么开播的时候在线人数很高,随着直播时长越往后在线人数越少?
新号在线人数稳定一段时间后,为什么最近在线人数突然就掉到很少了?
抖音流量池到底是什么概念?
直播间场景的重要性以及有什么影响?
表单的数据采集和提交
表单按钮(下)
表单按钮(上)
20个实用的JavaScript代码片段,助你成为更好的开发者
9个有用又有趣的CSS属性
技术干货






