美文网首页
JS获取对象键值对中key值的方法

JS获取对象键值对中key值的方法

作者: 唐人不自醉 | 来源:发表于2018-11-20 01:21 被阅读181次

使用Object.keys


Object.keys( ) 会返回一个数组,数组中是这个对象的key值列表

所以只要Object.keys(a)[0], 就可以得只包含一个键值对的key值

下面是MDN中对Object.keys的描述

**Object.keys()** 方法会返回一个由一个给定对象的自身可枚举属性组成的数组,数组中属性名的排列顺序和使用 for...in 循环遍历该对象时返回的顺序一致 (两者的主要区别是 一个 for-in 循环还会枚举其原型链上的属性)

语法

Object.keys(obj)
参数

obj

要返回其枚举自身属性的对象。
返回值

一个表示给定对象的所有可枚举属性的字符串数组。

描述

Object.keys 返回一个所有元素为字符串的数组,其元素来自于从给定的object上面可直接枚举的属性。这些属性的顺序与手动遍历该对象属性时的一致。

例子

// simple array
var arr = ['a', 'b', 'c'];
console.log(Object.keys(arr)); // console: ['0', '1', '2']
 
// array like object
var obj = { 0: 'a', 1: 'b', 2: 'c' };
console.log(Object.keys(obj)); // console: ['0', '1', '2']
 
// array like object with random key ordering
var anObj = { 100: 'a', 2: 'b', 7: 'c' };
console.log(Object.keys(anObj)); // console: ['2', '7', '100']
 
// getFoo is a property which isn't enumerable
var myObj = Object.create({}, {
  getFoo: {
    value: function () { return this.foo; }
  } 
});
myObj.foo = 1;
console.log(Object.keys(myObj)); // console: ['foo']

如果你想获取一个对象的所有属性,,甚至包括不可枚举的,请查看Object.getOwnPropertyNames

注意

在ES5里,如果此方法的参数不是对象(而是一个原始值),那么它会抛出 TypeError。在ES2015中,非对象的参数将被强制转换为一个对象。

Object.keys("foo");
// TypeError: "foo" is not an object (ES5 code)
 
Object.keys("foo");
// ["0", "1", "2"]                   (ES2015 code)

Polyfill

要在原生不支持的旧环境中添加兼容的Object.keys,请复制以下代码段:

if (!Object.keys) {
  Object.keys = (function () {
    var hasOwnProperty = Object.prototype.hasOwnProperty,
        hasDontEnumBug = !({toString: null}).propertyIsEnumerable('toString'),
        dontEnums = [
          'toString',
          'toLocaleString',
          'valueOf',
          'hasOwnProperty',
          'isPrototypeOf',
          'propertyIsEnumerable',
          'constructor'
        ],
        dontEnumsLength = dontEnums.length;
 
    return function (obj) {
      if (typeof obj !== 'object' && typeof obj !== 'function' || obj === null) throw new TypeError('Object.keys called on non-object');
 
      var result = [];
 
      for (var prop in obj) {
        if (hasOwnProperty.call(obj, prop)) result.push(prop);
      }
 
      if (hasDontEnumBug) {
        for (var i=0; i < dontEnumsLength; i++) {
          if (hasOwnProperty.call(obj, dontEnums[i])) result.push(dontEnums[i]);
        }
      }
      return result;
    }
  })()
};

上面的代码在IE7(也许IE8也是)下有个问题,就是如果传入一个来自其他 window 对象下的对象时,不可枚举的属性也会获取到。

相关文章

  • JS获取对象键值对中key值的方法

    使用Object.keys Object.keys( ) 会返回一个数组,数组中是这个对象的key值列表 所以只要...

  • js获取对象中的键值对

    使用原生js循环获取对象中的键值对,也就是 key : value

  • 对象

    1.对象,无序的数据集合,由若干键值对构成。2.{key : value}是JS对象字面量写法3.获取对象的方式....

  • 关于PHP遇到undefined

    当使用js进行请求时,请求数据格式为对象时,对象包含的键值对含有值为undefined,PHP时获取不到该键值对的...

  • Objective-C 语言特性之KVC

    KVC 简单来说,就是键值编码,通过获取对象对应的key,来获取和设置对应的属性值。使用过程中可以通过key,也可...

  • iOS 关联对象笔记

    方法 三个方法的作用分别是: 以键值对形式添加关联对象 根据 key 获取关联对象 移除所有关联对象 例子 下面A...

  • 理解对象、构造对象和抽象重复

    JS中的对象 一系列的无序的 key: value 的集合 (数组、函数、对象) 获取对应值 对象.属性 / 对象...

  • 给json中动态添加多个键值对,以及如何获取json对象中的ke

    一,给json中动态添加多个键值对 二,获取json对象的key和value

  • Python中的字典

    Python中的字典就是JavaScript中的对象创建字典 访问字典中的值 使用len()方法获取字典中键值对的...

  • js对象

    对象就是一种无序的数据集合,若干个“键值对”(key-value)构成。 key值value值之间用冒号,每个键值...

网友评论

      本文标题:JS获取对象键值对中key值的方法

      本文链接:https://www.haomeiwen.com/subject/sdnzfqtx.html