前言
Object 是 JavaScript 中非常重要的一个对象,其是一个无序键值对集合,非常适合用于存储一些需要按照键名访问的数据,例如配置文件、请求参数等。ES7 为 Object 引入了两个新的方法:Object.values 和 Object.entries。这两个方法非常有用,可以让我们轻松地获取对象中的键值对数据。本文将详细介绍这两个方法的用法和意义,帮助读者更好地理解 Object 对象及其相关概念。
Object.values 方法
Object.values() 方法返回一个给定对象中所有可枚举属性的值的数组,其顺序与对象内部属性的枚举顺序一致。
语法
Object.values(obj)
- obj:要返回其可枚举属性的值的对象
示例
const obj = { a: 1, b: 2, c: 3 }; const values = Object.values(obj); console.log(values); // [1, 2, 3]
意义
Object.values() 方法的用途非常广泛,在实际开发中常常用于获取 JSON 数据中的所有值,从而进行相关操作,例如筛选、过滤、排序等。与之相比,调用 Object.keys() 方法可以获取对象的键名数组,但无法直接获取键值数组。因此,Object.values() 方法的出现大大简化了程序的复杂度,提高了开发效率。
Object.entries 方法
Object.entries() 方法返回一个给定对象自身可枚举属性 [键, 值] 的数组,其顺序与使用 for...in 循环遍历该对象时返回的顺序一致。
语法
Object.entries(obj)
- obj:要返回其可枚举属性的键值对的对象
示例
const obj = { a: 1, b: 2, c: 3 }; const entries = Object.entries(obj); console.log(entries); // [["a", 1], ["b", 2], ["c", 3]]
意义
与 Object.values() 方法类似,Object.entries() 方法的实际应用也非常广泛。使用这个方法可以非常方便地遍历对象中的每个属性,同时获取其对应的键名与键值。请注意,这里的键名是字符串类型,而不是数值或其他类型,因此在后续操作中需要进行类型转换。
总结
ES7 中的 Object.values 和 Object.entries 方法是非常实用的方法,可以用来获取对象中的所有键值对。Object.values() 方法获取对象所有键的值,而 Object.entries() 方法获取对象所有键值对。这两个方法的使用频率非常高,在实际开发过程中,可以大大提高开发效率,降低程序的复杂度。在使用这两个方法时,需要特别注意键名类型的转换问题,以避免出现错误。
参考资料
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6538e67a7d4982a6eb20f0df