有時,我們需要使用 JavaScript 中的某些資料結構將鍵對應到特定值。例如,在 JavaScript 中將使用者詳細資訊儲存在鍵值對中非常有用。
我們可以使用不同的資料結構,例如JavaScript中的物件或映射,以鍵值格式儲存資料。
在 JavaScript 中,物件允許我們以鍵值格式儲存資料。我們可以使用鍵和物件來從物件中取得資料。
使用者可以依照下面的語法使用JavaScript中的物件來儲存鍵值對
let object = {}; object[key] = value;
在上面的語法中,我們建立了空物件。此外,我們將特定鍵的值儲存在物件中
在下面的範例中,我們建立了包含數字的keysArray。 valueArray 包含表示數字的不同字串。
之後,我們使用for迴圈來遍歷keysArray。我們從keysArray的第i個索引中取得鍵,並從valuesArray的第i個索引中取得值。對於每個鍵,我們將值儲存在物件中。
最後,我們列印了物件的所有鍵和值。
<html> <body> <h2>Using the <i> objects </i> to store a key => value pairs in JavaScript.</h2> <div id = "output"> </div> <script> var output = document.getElementById('output'); let keysArray = [1, 2, 3, 4, 5, 6]; let valuesArray = ["one", "two", "three", "four", "five", "six"]; let object = {}; for (let i = 0; i < keysArray.length; i++) { object[keysArray[i]] = valuesArray[i]; } for (let key in object) { output.innerHTML += "Key - " + key + " , value - " + object[key] + "<br>"; } </script> </body> </html>
我們也可以使用映射以鍵值格式儲存資料。 Map 類別包含 set() 方法來設定數據,並以鍵和值作為參數。另外,map 類別包含 get() 方法,該方法將鍵作為參數並傳回映射的值。
使用者可以按照以下語法使用映射在 JavaScript 中儲存鍵值對。
let mapData = new Map(); mapData.set(key, value)
我們在上述語法中使用了 Map() 建構子來建立一個新的地圖物件。此外,我們也使用 set() 方法來設定鍵和值。
在下面的範例中,mapKeys 陣列包含數字字串。我們迭代數組並將鍵值對設定為映射。在 for 迴圈中,我們使用 set() 方法來設定映射中的鍵值。此外,我們也傳遞了 mapKeys 陣列中的鍵作為第一個參數,並將索引作為第二個參數。
<html> <body> <h2>Using the <i> mapData </i> to store a Key => value pairs in JavaScript.</h2> <div id = "output"> </div> <script> var output = document.getElementById('output'); let mapKeys = ["one", "two", "three", "four", "five", "six"]; // Creating the new map let mapData = new Map(); for (let i = 0; i < mapKeys.length; i++) { mapData.set(mapKeys[i], i) } for (let mapKey of mapData.keys()) { output.innerHTML += "mapKey - " + mapKey + " , value - " + mapData.get(mapKey) + "<br>"; } </script> </body> </html>
array.reduce()方法透過減少數組將數組轉換為單一元素。我們可以使用reduce()方法透過將陣列資料以鍵值對格式儲存在物件內部,將整個陣列轉換為單一物件。
使用者可以按照下面的語法使用 array.reduce() 方法將數組資料儲存在物件中。
let object = arrayOfValues.reduce((obj, element, index) => { obj[index * 2] = element; return obj; }, {})
我們在上面的語法中使用 {} (空物件)初始化了物件。我們將數組的每個元素儲存在 obj 物件中,並從 array.reduce() 方法傳回它。
在下面的範例中,我們有一個 arrayOfValues 變量,其中包含字串格式的不同程式語言。我們已經將陣列轉換為物件格式,物件格式以鍵值格式儲存陣列資料。
在 array.reduce() 方法中,obj 物件包含上次迭代更新的鍵值。在目前迭代中,我們使用索引 *2 作為鍵,使用陣列元素作為物件元素的值。之後,我們返回 obj。
<html> <body> <h2>Using the <i> Array.reduce() method </i> to store a key => value pairs in JavaScript.</h2> <div id = "output"> </div> <script> var output = document.getElementById('output'); let arrayOfValues = ["TypeScript", "JavaScript", "ReactJS", "NextJS", "Python", "C"]; let object = arrayOfValues.reduce((obj, element, index) => { // store element to object obj[index * 2] = element; // return updated object return obj; }, {}) for (let objKey in object) { output.innerHTML += "Key - " + objKey + " , value - " + object[objKey] + "<br>"; } </script> </body> </html>
我們在 JavaScript 中使用了 map、object 和 array.reduce() 方法以鍵值格式儲存資料。地圖是以鍵值格式儲存資料的最佳方式。
以上是如何在 JavaScript 中儲存 key => value 陣列?的詳細內容。更多資訊請關注PHP中文網其他相關文章!