美文网首页前端程序员干货计算机微刊程序员
ES6奇技淫巧之Object.keys方法详解

ES6奇技淫巧之Object.keys方法详解

作者: 巩小白 | 来源:发表于2017-09-13 17:33 被阅读0次

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

/* Array 对象 */ 
let arr = ["a", "b", "c"];
console.log(Object.keys(arr)); 
// ['0', '1', '2']
/* 类数组 对象 */ 
let obj = { 0 : "a", 1 : "b", 2 : "c"};
console.log(Object.keys(obj)); 
// ['0', '1', '2']
// 类数组 对象, 随机 key 排序 
let anObj = { 100: 'a', 2: 'b', 7: 'c' }; 
console.log(Object.keys(anObj)); 
// ['2', '7', '100']
/* getFoo 是个不可枚举的属性 */ 
var my_obj = Object.create(
   {}, 
   { getFoo : { value : function () { return this.foo } } }
);
my_obj.foo = 1;
console.log(Object.keys(my_obj)); 
// ['foo']
  • 要在原生不支持的旧环境中添加兼容的 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;
    }
  })()
};

相关文章

  • ES6奇技淫巧之Object.keys方法详解

    Object.keys() 方法会返回一个由一个给定对象的自身可枚举属性组成的数组,数组中属性名的排列顺序和使用 ...

  • Object.keys方法之详解

    在实际开发中,我们有时需要知道对象的所有属性,原生js给我们提供了一个很好的方法:Object.keys(),该方...

  • Object.keys方法之详解

    https://www.cnblogs.com/llcdxh/p/9476347.html

  • Object.keys方法之详解

    一、语法 Object.keys(obj) 参数:要返回其枚举自身属性的对象 返回值:一个表示给定对象的所有可枚举...

  • Object.keys方法之详解

    语法: Object.keys(obj)参数:要返回其枚举自身属性的对象返回值:一个表示给定对象的所有可枚举属性的...

  • 判断对象为空

    记录两种比较简单的方法 ES6的Object.keys()方法 ES6的新方法, 返回值也是对象中属性名组成的数组...

  • 详解Object.keys方法

    在实际开发中,我们有时需要知道对象的所有属性,原生js给我们提供了一个很好的方法:Object.keys(),该方...

  • Object.keys方法详解

    1.MDN中对于Object.keys方法的描述 2.用法 处理对象,返回可枚举的属性数组 3.常用方式 4.Ob...

  • js 检测数组是否为空

    es6中可以使用Object.keys(obj)

  • JS常用判断object是否为空的方法

    1.使用es6方法 (推荐) 避免传参null、undefined报错 使用Object.keys()判断对象ke...

网友评论

    本文标题:ES6奇技淫巧之Object.keys方法详解

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