Javascript中Object和Map之间的转换方法
更新时间:2023年06月21日 08:46:50 作者:tookingHome
在许多编程语言中,Object和Map都是用于存储键值对的数据结构,下面这篇文章主要给大家介绍了关于Javascript中Object和Map之间的转换方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
简单的区分Map和Object
Map是ES6退出的一个类型,特点:任何值都可作为属性名
Object特点:属性名只能是字符串(一开始我也不信,测试后才发现的)
代码

图片

创建一个map类型
new Map([ [key, value], [key1, value1] ])
简单的介绍下面两个方法
- Object.entries()方法返回一个数组,成员是参数对象自身的(不含继承的)所有可遍历(enumerable)属性的键值对数组。
- Object.fromEntries()方法是Object.entries()的逆操作,用于将一个键值对数组转为对象。
Object类型 转 Map类型
这里主要用到了Object.entries的特性,
Object.entries 返回一个二维数组,其中数组中的第一个值是key,第二个值是value
const obj = {
a: '我是obj.a',
b: '我是obj.b',
c: '我是obj.c',
}
console.log(obj)
const map = new Map(Object.entries(obj))
console.log(map)
console.log(map.get('a'), '我是map 属性名')
console.log(map.get('b'), '我是map 属性名')
Map类型转Object类型
const arr = [1, 2, 3],
obj = { a: '1', b: 2 },
number = 22
const map = new Map()
map.set(arr, '我是map的第1个值,我是数组')
map.set(obj, '我是map的第2个值,我是对象')
map.set(number, '我是map的第3个值, 我是简单数据类型')
const newObj = Object.fromEntries(map.entries())
console.log(newObj, '我是新对象')
console.log('新对象类型', typeof newObj)
总结
到此这篇关于Javascript中Object和Map之间的转换方法的文章就介绍到这了,更多相关js Object和Map转换内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
javascript中的toFixed固定小数位数 简单实例分享
这篇文章介绍了toFixed固定小数位数的简单例子,有需要的朋友可以参考一下2013-07-07
webpack自动化打包webpack-dev-server的实现
我们每次改完要打包的资源文件,和配置文件都是是输入npx webpack命令手动打包的,本文就来介绍一下webpack自动化打包webpack-dev-server的实现,具有一定的参考价值,感兴趣的可以了解一下2023-07-07
JS中type="button"和type="submit"的区别
Submit是专门用于提交表单的Button,与Button的区别主要有两点:type=button 就单纯是按钮功能,type=submit 是发送表单 。下面通过本文给大家分享JS中type="button"和type="submit"的区别,感兴趣的的朋友一起看看吧2017-07-07


最新评论