在原生不支持的旧环境中添加兼容的Object.keys实现方法

前端之家收集整理的这篇文章主要介绍了在原生不支持的旧环境中添加兼容的Object.keys实现方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

如下所示:

方法,只取自身有的属性; 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;
}
})()
};

以上这篇在原生不支持的旧环境中添加兼容的Object.keys实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

原文链接:https://www.f2er.com/js/36526.html

猜你在找的JavaScript相关文章