中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

JS中Object.fromEntries和Object.entries的應用

發布時間:2020-06-19 10:40:13 來源:億速云 閱讀:485 作者:Leah 欄目:web開發

這篇文章給大家分享的是有關JS中Object.fromEntries和Object.entries的應用,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲。

object.entries() 轉換一個object為array。但是,如果你想做相反的事情怎么辦?不用再想了! 使用 Object.fromEntries() 來把array轉換為object。

const keyValuePair = [
  ['cow', 'val1'],
  ['pig', 'val2'],
];
Object.fromEntries(keyValuePair);
// { cow: 'val1', pig: 'val2' }

Object.fromEntries

我們先指出對象的解剖方法,對象是有一個鍵和一個值的東西。

const object = {
  key: 'value',
};

如果我們想將某物轉換為對象,我們需要傳遞具有這兩個要求的東西:keyvalue

滿足這些要求的參數有兩種:

  1. 具有嵌套鍵值對的數組
  2. Map對象

用Object.fromEntries將數組轉為對象

這是帶有鍵值對的嵌套數組

const nestedArray = [
  ['key 1', 'value 1'],
  ['key 2', 'value 2'],
];

當我們將 Object.fromEntries 應用于它時,我們可以從中獲取對象。

Object.fromEntries(nestedArray);
// { key 1: "value 1", key 2: "value 2"}

用Object.fromEntries將Map轉為對象

JavaScript ES6為我們帶來了一個名為map的新對象,它與對象非常相似。

讓我們創建新的Map對象

// 使用構造函數
const map = new Map([
  ['key 1', 'value 1'],
  ['key 2', 'value 2'],
]);
// 或者我們可以使用實例方法,"set"
const map = new Map();
map.set('key 1', 'value 1');
map.set('key 2', 'value 2');
// 結果
// Map(2) {"key 1" => "value 1", "key 2" => "value 2"}

現在,我們使用 Object.fromEntries 將Map轉換為對象

Object.fromEntries(map);
// { key 1: "value 1", key 2: "value 2"}

Object.fromEntries與其他類型的類型錯誤

當你試圖將其他數據類型傳遞到 Object.fromEntries 時,請小心,所有這些都會拋出一個錯誤

?未捕獲的類型錯誤(Uncaught TypeError)

JS中Object.fromEntries和Object.entries的應用

確保只傳遞鍵值對

Object.fromEntries vs Object.entries

Object.fromEntriesObject.entries 的效果相反。所以 Object. entries 將轉換我們的數組并返回一個新的嵌套的鍵值對數組。而 Object.fromEntries 將把這個數組轉回一個對象。

const object = { key1: 'value1', key2: 'value2' };
const array = Object.entries(object);
// [ ["key1", "value1"], ["key2", "value2"] ]
Object.fromEntries(array);
// { key1: 'value1', key2: 'value2' }

Object到Object的轉換

如果你閱讀了原始的TC39提案,這就是引入此新方法的原因。隨著 Object.entries 的引入,沒有一種簡單的方法可以將結果轉換回對象。

通常,當我們選擇使用 Object.entries 時,是因為它使我們可以訪問許多漂亮的數組方法,例如 filter。但是在完成轉換之后,我們有點被該數組所困擾。

const food = { meat: 'v1', broccoli: 'v2', carrot: 'v3' };
// Stuck in Array land
const vegetarian = Object.entries(food).filter(
  ([key, value]) => key !== 'meat',
);
// [ ["broccoli", "v2"], ["carrot", "v3"] ]

我們可以利用所有這些有用的數組方法,但仍然可以找回我們的對象,最后,從對象到對象的轉換。

const food = { meat: 'v1', broccoli: 'v2', carrot: 'v3' };
// Yay, still in Object land
const vegetarian = Object.fromEntries(
  Object.entries(food).filter(([key, value]) => key !== 'meat'),
);
// { broccoli: 'v2', carrot: 'v3' }

瀏覽器支持

除了Internet Explorer,大多數主流瀏覽器都支持此方法 。

JS中Object.fromEntries和Object.entries的應用

關于JS中Object.fromEntries和Object.entries的應用就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

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

AI

高安市| 苍山县| 威信县| 元朗区| 大庆市| 常熟市| 蓝田县| 宁明县| 额济纳旗| 陈巴尔虎旗| 施秉县| 周宁县| 库尔勒市| 深圳市| 林口县| 贵阳市| 房产| 拜泉县| 保康县| 博湖县| 和林格尔县| 汉源县| 琼结县| 额尔古纳市| 高密市| 兴仁县| 寻乌县| 余姚市| 乌拉特中旗| 额尔古纳市| 东丽区| 巨鹿县| 柳州市| 开封县| 永宁县| 鲁甸县| 高邮市| 康乐县| 福清市| 桐梓县| 陇西县|