溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

在JavaScript中如何使用延展操作運算符

發(fā)布時間:2021-08-16 11:24:18 來源:億速云 閱讀:185 作者:chen 欄目:web開發(fā)

本篇內容主要講解“在JavaScript中如何使用延展操作運算符”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“在JavaScript中如何使用延展操作運算符”吧!

ES6中引入了延展操作運算符(...)。

延展操作運算符將可迭代的對象擴展為其單獨的元素,可迭代對象是可以使用 for 循環(huán)進行循環(huán)的任何對象。

可迭代的示例:Array,String,Map,Set,DOM節(jié)點。

1. 在log中使用延展操作運算符

你可以在 console.log 中對可迭代對象使用延展操作操作符

let fruits = ['', '', '', '']; console.log(...fruits); //

2. 用延展操作運算符復制數(shù)組

let fruits = ['', '', '', '']; let fruitsCopy = [ ...fruits ];  console.log(...fruitsCopy); //

復制對象

let user = {name : "John", age : 20 } let userCopy = {...user}

延展操作運算符不執(zhí)行深度復制。

3. 延展操作運算符合并

let fruits = ['', '', '', '']; let vegetables = ['', '', '']; let fruitsAndVeg = [...fruits, ...vegetables]

合并對象

合并對象時,如果已經存在某個鍵,則將其替換為具有相同鍵的最后一個對象。

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. 延展操作運算符在解構變量中

let [melon, ...fruits ] = ['', '', '', '']; melon; //  fruits; // [ '', '', '']

解構對象

let user = {name : "Ram", age: 20, salary: '20K', job : "Tester" }; let { name, age, ...details } = user; name; // Ram age; // 20 details; // {salary: '20K', job : 'Tester'};

6. 將NodeList對象轉換為數(shù)組

NodeList類似于數(shù)組,但是沒有 Array 的所有方法,例如 forEach,map,filter 等。

let nodeList = document.querySelectorAll('.class') var nodeArray = [...nodeList]

7. 將字符串轉換為字符

字符串也是可迭代的對象,因此我們也可以使用 ... 來字符串。

let name = "Ram"; let chars = [...name]; // ["R", "a", "m"]

8. 從數(shù)組中刪除重復項

let num = [1, 3, 1, 3, 3, 1]; let uniqueNum = [...new Set(num)]; uniqueNum; //[ 1, 3 ]

到此,相信大家對“在JavaScript中如何使用延展操作運算符”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI