JavaScript中使用Spread運算符的八種方法總結(jié)
Spread運算符
允許從 iterable 表達(dá)式(如另一個數(shù)組文本)初始化部分?jǐn)?shù)組文本,或允許表達(dá)式擴展到多個參數(shù)(在函數(shù)調(diào)用中)。
語法
var array = [[arg0ToN ,] ...iterable [, arg0ToN]] func([args ,] ...iterable [, args | ...iterable])
參數(shù)
iterable
必需。 迭代對象。
arg0ToN
可選。 數(shù)組文本的一個或多個元素。
args
可選。 函數(shù)的一個或多個參數(shù)。
本文將帶大家了解如何在JavaScript中使用Spread(延展操作)運算符。
ES6中引入了延展操作運算符(...)。
延展操作運算符將可迭代的對象擴展為其單獨的元素,可迭代對象是可以使用 for 循環(huán)進行循環(huán)的任何對象。
可迭代的示例:Array,String,Map,Set,DOM節(jié)點。
1.在log中使用延展操作運算符
你可以在 console.log 中對可迭代對象使用延展操作操作符
let fruits = [’🍈’, ’🍉’, ’🍋’, ’🍌’];console.log(...fruits); //🍈 🍉 🍋 🍌
2.用延展操作運算符復(fù)制數(shù)組
let fruits = [’🍈’, ’🍉’, ’🍋’, ’🍌’];let fruitsCopy = [ ...fruits ];console.log(...fruitsCopy); //🍈 🍉 🍋 🍌
復(fù)制對象
let user = {name : 'John', age : 20 }let userCopy = {...user}
延展操作運算符不執(zhí)行深度復(fù)制。
3.延展操作運算符合并
let fruits = [’🍈’, ’🍉’, ’🍋’, ’🍌’];let vegetables = [’🍅’, ’🍆’, ’🥒’];let fruitsAndVeg = [...fruits, ...vegetables]
合并對象
合并對象時,如果已經(jīng)存在某個鍵,則將其替換為具有相同鍵的最后一個對象。
let user1 = {name : 'John', age : 20 };let user2 = {name : 'Ram', salary: ’20K’ };let userCopy = {...user1, ...user2};userCopy ; // {name : 'Ram', age :20 , salary : ’20K’};
4.延展操作運算符作為參數(shù)傳遞
function sum(a, b) { return a+b;}let num = [1,2];sum(...num); // 3
與 math 函數(shù)一起使用
let num = [5,9,3,5,7];Math.min(...num);Math.max(...num);
5.延展操作運算符在解構(gòu)變量中
let [melon, ...fruits ] = [’🍉’, ’🍋’, ’🍌’, ’🍊’];melon; //🍉fruits; // [ ’🍋’, ’🍌’, ’🍊’]
解構(gòu)對象
let user = {name : 'Ram', age: 20, salary: ’20K’, job : 'Tester' };let { name, age, ...details } = user;name; // Ramage; // 20details; // {salary: ’20K’, job : ’Tester’};
6.將NodeList對象轉(zhuǎn)換為數(shù)組
NodeList類似于數(shù)組,但是沒有 Array 的所有方法,例如 forEach,map,filter 等。
let nodeList = document.querySelectorAll(’.class’)var nodeArray = [...nodeList]
7.將字符串轉(zhuǎn)換為字符
字符串也是可迭代的對象,因此我們也可以使用 ... 來字符串。
let name = 'Ram';let chars = [...name]; // ['R', 'a', 'm']
8.從數(shù)組中刪除重復(fù)項
let num = [1, 3, 1, 3, 3, 1];let uniqueNum = [...new Set(num)];uniqueNum; //[ 1, 3 ]
總結(jié)
到此這篇關(guān)于JavaScript中使用Spread運算符的八種方法就介紹到這了,更多相關(guān)JavaScript使用Spread運算符內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. idea設(shè)置提示不區(qū)分大小寫的方法2. .NET SkiaSharp 生成二維碼驗證碼及指定區(qū)域截取方法實現(xiàn)3. HTTP協(xié)議常用的請求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))4. css代碼優(yōu)化的12個技巧5. CentOS郵件服務(wù)器搭建系列—— POP / IMAP 服務(wù)器的構(gòu)建( Dovecot )6. ASP.NET MVC通過勾選checkbox更改select的內(nèi)容7. 原生JS實現(xiàn)記憶翻牌游戲8. Django使用HTTP協(xié)議向服務(wù)器傳參方式小結(jié)9. django創(chuàng)建css文件夾的具體方法10. IntelliJ IDEA創(chuàng)建web項目的方法
