在原生不支持的旧环境中添加兼容的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






