首頁  >  文章  >  web前端  >  如何在 JavaScript 中儲存 key => value 陣列?

如何在 JavaScript 中儲存 key => value 陣列?

PHPz
PHPz轉載
2023-09-09 09:45:09971瀏覽

如何在 JavaScript 中存储 key => value 陣列?

有時,我們需要使用 JavaScript 中的某些資料結構將鍵對應到特定值。例如,在 JavaScript 中將使用者詳細資訊儲存在鍵值對中非常有用。

我們可以使用不同的資料結構,例如JavaScript中的物件或映射,以鍵值格式儲存資料。

使用物件在 JavaScript 中儲存鍵 => 值

在 JavaScript 中,物件允許我們以鍵值格式儲存資料。我們可以使用鍵和物件來從物件中取得資料。

文法

使用者可以依照下面的語法使用JavaScript中的物件來儲存鍵值對

let object = {};
object[key] = value;

在上面的語法中,我們建立了空物件。此外,我們將特定鍵的值儲存在物件中

範例 1

在下面的範例中,我們建立了包含數字的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> 

在 JavaScript 中使用映射儲存 key => value

我們也可以使用映射以鍵值格式儲存資料。 Map 類別包含 set() 方法來設定數據,並以鍵和值作為參數。另外,map 類別包含 get() 方法,該方法將鍵作為參數並傳回映射的值。

文法

使用者可以按照以下語法使用映射在 JavaScript 中儲存鍵值對。

let mapData = new Map();
mapData.set(key, value) 

我們在上述語法中使用了 Map() 建構子來建立一個新的地圖物件。此外,我們也使用 set() 方法來設定鍵和值。

範例 2

在下面的範例中,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>

在 JavaScript 中使用 array.reduce() 方法儲存 key => value

array.reduce()方法透過減少數組將數組轉換為單一元素。我們可以使用reduce()方法透過將陣列資料以鍵值對格式儲存在物件內部,將整個陣列轉換為單一物件。

文法

使用者可以按照下面的語法使用 array.reduce() 方法將數組資料儲存在物件中。

let object = arrayOfValues.reduce((obj, element, index) => {
   obj[index * 2] = element;
   return obj;
}, {}) 

我們在上面的語法中使用 {} (空物件)初始化了物件。我們將數組的每個元素儲存在 obj 物件中,並從 array.reduce() 方法傳回它。

範例 3

在下面的範例中,我們有一個 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中文網其他相關文章!

陳述:
本文轉載於:tutorialspoint.com。如有侵權,請聯絡admin@php.cn刪除