ES6中Array.copyWithin()函數(shù)的用法實例詳解
ES6為Array增加了copyWithin函數(shù),用于操作當前數(shù)組自身,用來把某些個位置的元素復制并覆蓋到其他位置上去。
Array.prototype.copyWithin(target, start = 0, end = this.length)
該函數(shù)有三個參數(shù)。
target:目的起始位置。
start:復制源的起始位置,可以省略,可以是負數(shù)。
end:復制源的結(jié)束位置,可以省略,可以是負數(shù),實際結(jié)束位置是end-1。
例:
把第3個元素(從0開始)到第5個元素,復制并覆蓋到以第1個位置開始的地方。
下面的紅色塊是復制目標的起始位置,黃色塊為復制的源。
const arr1 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11] arr1.copyWithin(1, 3, 6) console.log('%s', JSON.stringify(arr1))
結(jié)果:
[1,4,5,6,5,6,7,8,9,10,11]
start和end都是可以省略。
start省略表示從0開始,end省略表示數(shù)組的長度值。
目標的位置不夠的,能覆蓋多少就覆蓋多少。
const arr2 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11] arr2.copyWithin(3) console.log('%s', JSON.stringify(arr2))
結(jié)果:
[1,2,3,1,2,3,4,5,6,7,8]
start和end都可以是負數(shù),負數(shù)表示從右邊數(shù)過來第幾個。
const arr3 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11] arr3.copyWithin(3, -3, -2) console.log('%s', JSON.stringify(arr3))
結(jié)果:
[1,2,3,9,5,6,7,8,9,10,11]
總結(jié)
以上所述是小編給大家介紹的ES6中Array.copyWithin()函數(shù)的用法實例詳解,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
相關(guān)文章
javascript獲取和判斷瀏覽器窗口、屏幕、網(wǎng)頁的高度、寬度等
這篇文章主要介紹了javascript獲取和判斷瀏覽器窗口、屏幕、網(wǎng)頁的高度、寬度等,需要的朋友可以參考下2014-05-05Easy.Ajax 部分源代碼 支持文件上傳功能, 兼容所有主流瀏覽器
下面是Easy.Ajax類的初稿,如須發(fā)表,在代碼上還要修改以達到最簡,但API是不會變了2011-02-02兼容ie ff div 層 打開+關(guān)閉+ 拖動+遮罩+移動+動畫改變高寬
div層 打開+關(guān)閉+ 拖動+遮罩+移動+動畫改變高寬的實例js代碼2008-07-07