ES6数组复制和填充方法copyWithin()、fill()的具体使用

 更新时间:2021年10月27日 09:50:06   作者:代码搬运媛  
本文主要介绍了ES6数组复制和填充方法copyWithin()、fill()的具体使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

copyWithin()、fill()共同点

  • 需要指定一个数组实例的范围:包含开始索引,不包含结束索引。
  • 使用这个方法会改变数组内容,但不会改变数组的大小。

批量复制 copyWithin()

  • copyWithin() 方法用于从数组的指定位置拷贝元素到数组的另一个指定位置中。
  • copyWithin()会按照指定范围浅复制数组中的部分内容,然后将它们插入到指定索引开始的位置。

语法

array.copyWithin(target, start, end)

参数:

参数 描述
target 必需。复制到指定目标索引位置。
start 可选。元素复制的起始位置。
end 可选。停止复制的索引位置 (默认为 array.length)。如果为负值,表示倒数。

返回值:返回复制之后的数组

代码实例:

// 复制数组的前面两个元素到后面两个元素上:
var fruits = ["Banana", "Orange", "Apple", "Mango"]; 
fruits.copyWithin(2, 0);//Banana,Orange,Banana,Orange

// 复制数组的前面两个元素到第三和第四个位置上:
var fruits = ["Banana", "Orange", "Apple", "Mango", "Kiwi", "Papaya"]; 
fruits.copyWithin(2, 0, 2);//Banana,Orange,Banana,Orange,Kiwi,Papaya

填充数组方法 fill()

fill() 方法用于将一个固定值替换数组的元素。

语法:

array.fill(value, start, end)

参数:

参数 描述
value 必需。填充的值。
start 可选。开始填充位置。
end 可选。停止填充位置 (默认为 array.length)

返回值:数组

代码实例:

//填充 "Runoob" 到数组的最后两个元素:
var fruits = ["Banana", "Orange", "Apple", "Mango"]; 
fruits.fill("Runoob", 2, 4);//[ "Banana", "Orange", "Runoob", "Runoob" ]

//使用固定值填充数组:
var fruits = ["Banana", "Orange", "Apple", "Mango"]; 
fruits.fill("Runoob");//Runoob,Runoob,Runoob,Runoob

关于索引的计算方式,两种方法相同

  • 开始索引用于指定开始填充的位置,它是可选的。
  • 如果不提供结束索引,则一直填充到数组末尾。
  • 负值索引从数组末尾开始计算。也可以将负索引想象成数组长度加上它得到的一个正索引。
  • 静默忽略超出数组边界、零长度及方向相反的索引范围。

代码实例:

const zeroes = [0,0,0,0,0];

//用6填充索引大于等于3的元素
zeroes.fill(6, 3);//[0,0,0,6,6]
zeroes.fill(0);//重置

//用7填充索引大于等于1且小于3的元素
zeroes.fill(7,1,3);//[0,7,7,0,0]
zeroes.fill(0);//重置

//用8填充索引大于等于1且小于4的元素
//(-4+zeroes.length=1) (-1+zeroes.length=4)
zeroes.fill(8,-4,-1);//[0,8,8,8,0]

//索引过低,忽略
zeroes.fill(1,-10,-6);//[0,0,0,0,0]
//索引过高,忽略
zeroes.fill(1,10,15);//[0,0,0,0,0]
//索引反向,忽略
zeroes.fill(2,4,2);//[0,0,0,0,0]
//索引部分可用,填充可用部分
zeroes.fill(4,3,10);//[0,0,0,4,4]

到此这篇关于ES6复制和填充方法copyWithin()、fill()的具体使用的文章就介绍到这了,更多相关ES6 copyWithin()、fill()内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • TypeScript中类的基础概念和使用详解

    TypeScript中类的基础概念和使用详解

    这篇文章主要为大家详细介绍了TypeScript 中类的概念和用法,文中的示例代码讲解详细,希望能帮助大家更好地理解和运用 TypeScript 中的类
    2023-06-06
  • JavaScript快速切换繁体中文和简体中文的方法及网站支持简繁体切换的绝招

    JavaScript快速切换繁体中文和简体中文的方法及网站支持简繁体切换的绝招

    这篇文章主要介绍了JavaScript快速切换繁体中文和简体中文方法的相关资料,需要的朋友可以参考下
    2016-03-03
  • JS代码简洁方式之函数方法详解

    JS代码简洁方式之函数方法详解

    这篇文章主要介绍了JS代码简洁方式之函数方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • JavaScript 防抖和节流遇见的奇怪问题及解决

    JavaScript 防抖和节流遇见的奇怪问题及解决

    这篇文章主要介绍了JavaScript 防抖和节流遇见的奇怪问题及解决,帮助大家更好的理解和使用JavaScript,感兴趣的朋友可以了解下
    2020-11-11
  • Javascript Memoization 缓存函数使用说明

    Javascript Memoization 缓存函数使用说明

    Memoization 是一种将函数返回值缓存起来的方法,学习js 面向对象的朋友可以参考下。
    2010-05-05
  • 浅析JavaScript中的变量提升

    浅析JavaScript中的变量提升

    这篇文章主要介绍了浅析JavaScript中的变量提升,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-06-06
  • 什么是JavaScript的防抖与节流

    什么是JavaScript的防抖与节流

    这篇文章主要介绍了什么是JavaScript的防抖与节流,防抖是在频繁触发某一个事件时,一段时间内不再触发该事件后才会去调用对应的回调函数,在设定间隔时间内如果下一次事件被触发, 那么就重新开始定时器,直到事件触发结束,节流看下面文章的具体介绍吧

    2021-12-12
  • 浅析JavaScript中的隐式类型转换

    浅析JavaScript中的隐式类型转换

    这篇文章主要是对JavaScript中的隐式类型转换进行了详细分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-12-12
  • 基于bootstrap的文件上传控件bootstrap fileinput

    基于bootstrap的文件上传控件bootstrap fileinput

    这篇文章主要为大家详细介绍了基于bootstrap的文件上传控件bootstrap fileinput,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • js实现星星打分效果的方法

    js实现星星打分效果的方法

    这篇文章主要介绍了js实现星星打分效果的方法,涉及javascript操作页面元素与样式的技巧,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-04-04

最新评论