共计 2166 个字符,预计需要花费 6 分钟才能阅读完成。
object.entries()
转换一个 objec 为 array。但是,如果你想做相反的事情怎么办?不用再想了!使用 Object.fromEntries()
来把 array 转换为 object ????。
const keyValuePair = [['cow', '????'],
['pig', '????'],
];
Object.fromEntries(keyValuePair);
// {cow: '????', pig: '????'}
Object.fromEntries
我们先指出对象的解剖方法,对象是有一个键和一个值的东西。
const object = {key: 'value',};
如果我们想将某物转换为对象,我们需要传递具有这两个要求的东西:key
和 value
。
满足这些要求的参数有两种:
- 具有嵌套键值对的数组
- 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)
确保只传递键值对 ????
Object.fromEntries vs Object.entries
Object.fromEntries
与 Object.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: '????', broccoli: '????', carrot: '????'};
// ???? Stuck in Array land
const vegetarian = Object.entries(food).filter(([key, value]) => key !== 'meat',
);
// [["broccoli", "????"], ["carrot", "????"] ]
我们可以利用所有这些有用的数组方法,但仍然可以找回我们的对象,最后,从对象到对象的转换 ????。
const food = {meat: '????', broccoli: '????', carrot: '????'};
// ???? Yay, still in Object land
const vegetarian = Object.fromEntries(Object.entries(food).filter(([key, value]) => key !== 'meat'),
);
// {broccoli: '????', carrot: '????'}
浏览器支持
除了 Internet Explorer,大多数主流浏览器都支持此方法 ????。
来源:https://medium.com/@samanthaming,作者:Samantha Ming,翻译:公众号《前端全栈开发者》
本文首发于公众号 《前端全栈开发者》ID:by-zhangbing-dev,第一时间阅读最新文章,会优先两天发表新文章。关注后私信回复:大礼包,送某网精品视频课程网盘资料,准能为你节省不少钱!