在原生不支持的旧环境中添加兼容的Object.keys实现方法
时间:2022-06-07 09:22:30|栏目:JavaScript代码|点击: 次
如下所示:
if (!Object.keys) { Object.keys = (function () { var hasOwnProperty = Object.prototype.hasOwnProperty, //原型上的方法,只取自身有的属性; hasDontEnumBug = !({toString: null}).propertyIsEnumerable('toString'), //ie6一下,!之后的内容为false; 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; } })() };
上一篇:javascript中的变量作用域以及变量提升详细介绍
栏 目:JavaScript代码
下一篇:没有了
本文标题:在原生不支持的旧环境中添加兼容的Object.keys实现方法
本文地址:http://www.codeinn.net/misctech/204081.html