一篇文章帶你了解JavaScript的解構賦值
1. 什么是解構賦值 ?
將屬性/值從對象/數(shù)組中取出,賦值給其他變量
通俗來說,即解析某一數(shù)據(jù)的結構,將我們想要的東西提取出來,賦值給變量或常量。
讓我們通過一個例子看看:
const [a, b, c] = [1, 2, 3]; console.log(a, b, c);
將數(shù)組的值獲取出來,賦值給a
, b
, c
2. 數(shù)組的解構賦值
模式(結構)匹配
即左邊與右邊的結構相同 (如左邊是數(shù)組,右邊也要是數(shù)組)
索引值相同的完成賦值
即左邊與右邊的索引值相同的完成賦值
通過例子來理解一下:
對于第一個:
let [e, [ , , f], g] = [1, [2, 4, 5], 3]; // 可以正確輸出 console.log(e, f, g);
但是如果寫成這樣,則會報錯。
let [e, [ , , f], [g]] = [1, [2, 4, 5], 3]; console.log(e, f, g);
因為左邊與右邊的結構不匹配,右邊索引為 2 的地方是個 3,而左邊是個數(shù)組,無法完成匹配。
對于第二個
let [, a, ] = [1, 2, 3]; console.log(a);
索引值相同的完成賦值,a
的索引值是 1,對應右邊索引值為 1 的值是 2,所以a = 2
。
2.1) 數(shù)組解構賦值的默認值
const [a, b] = [];console.log(a, b);
當左邊對應的索引在右邊為undefined
時(如右邊不存在這個值的情況),此時賦值的是undefined
那我們如何修改這個賦值呢 ?
通過在左邊給變量寫個 = 想要的值,即默認值。
所以,當左邊的值=== undefined
時,如果有默認值,左邊的值會等于默認值
const [a = 1, b = 2] = []; console.log(a, b);
2.2) 數(shù)組解構賦值的應用
類數(shù)組中的應用
比如arguments
中的應用
將arguments
中的值提取出來
function fun() { const [a, b, c] = arguments; console.log(a, b); } fun(1, 2, 3, 4);
比如NodeList
中的應用
在這里,將p
元素提取出來
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>解構賦值的應用</title> </head> <body> <p>one</p> <p>two</p> <p>three</p> <script> // 利用數(shù)組解構賦值將 p 元素獲取的同時解構出來 const [p1, p2, p3] = document.querySelectorAll('p'); console.log(p1, p2, p3); </script> </body> </html>
交換變量的值
let a = 1, b = 2; [a, b] = [b, a]; // 相當于 [a, b] = [2, 1]; console.log(a, b);
3. 對象的解構賦值
模式(結構)匹配
即左邊與右邊的結構相同 (如左邊是對象,右邊也要是對象)
屬性名相同的完成賦值
即左邊與右邊的屬性名相同的完成賦值
通過例子來理解一下:
const {val, objName} = {objName: "object", val: 1}; console.log(objName, val);
屬性名相同的完成賦值,不用管左邊屬性名出現(xiàn)的順序是否與右邊出現(xiàn)的順序一致。
這里還可以這么寫,給新的變量名賦值:
const {val: vvv, objName: objnnn} = {objName: "object", val: 1}; console.log(objnnn, vvv);
3.1) 對象解構賦值的默認值
與數(shù)組解構賦值類似
對象的屬性值=== undefined
時,如果有默認值,等于對應的默認值
const {age: val = 18} = {}; console.log(val);
3.2)對一個已聲明的變量解構賦值
在數(shù)組中,我們可以直接這么寫:
let a, b; [a, b] = [1, 2]; console.log(a, b);
但是,在對象中,直接這么寫則會報錯
let a, b; {a, b} = {a: 1, b: 2}; console.log(a, b);
因為在這里,左邊的花括號,瀏覽器會把它當成是一個代碼塊。
那么,我們如何解決這個問題呢 ?
在外面加個圓括號
let a, b; ({a, b} = {a: 1, b: 2}); console.log(a, b);
除此之外,對象的解構賦值可以取到繼承的屬性!
4. 字符串的解構賦值
可以用數(shù)組和對象的形式進行結構賦值
const [a, b] = "Hello"; // 左邊對象的屬性名對應右邊字符串的字符下標序號 const {2: c, 4: e} = "Hello"; console.log(a, b, c, e);
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!
相關文章
瀏覽器解析js生成的html出現(xiàn)樣式問題的解決方法
接觸css, javascript有三年多了,今天遇到的問題最令我不可思議,很容易給人一種錯覺,那就是js拼成的html結構肯定有問題2012-04-04javascript正則表達式中參數(shù)g(全局)的作用
表達式加上參數(shù)g之后,表明可以進行全局匹配,注意這里可以的含義。2010-11-11一文教你實現(xiàn)JavaScript防抖優(yōu)化代碼
在我們前端編程中,假如我們要給后端發(fā)送請求,萬一手抖多點了幾次,多發(fā)送了幾遍怎么辦,那就得用防抖處理,下面小編就來教大家如何實現(xiàn)防抖吧2023-11-11怎么理解wx.navigateTo的events參數(shù)使用詳情
這篇文章主要介紹了怎么理解wx.navigateTo的events參數(shù)使用詳情,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-05-05