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

2018-06-24 00:10:38来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

 1 if (!Object.keys) {
 2   Object.keys = (function () {
 3     var hasOwnProperty = Object.prototype.hasOwnProperty, //原型上的方法,只取自身有的属性;
 4         hasDontEnumBug = !({toString: null}).propertyIsEnumerable('toString'), //ie6一下,!之后的内容为false;
 5         dontEnums = [
 6           'toString',
 7           'toLocaleString',
 8           'valueOf',
 9           'hasOwnProperty',
10           'isPrototypeOf',
11           'propertyIsEnumerable',
12           'constructor'
13         ],
14         dontEnumsLength = dontEnums.length;
15 
16     return function (obj) {
17       if (typeof obj !== 'object' && typeof obj !== 'function' || obj === null) throw new TypeError('Object.keys called on non-object');
18 
19       var result = [];
20 
21       for (var prop in obj) {
22         if (hasOwnProperty.call(obj, prop)) result.push(prop);
23       }
24 
25       if (hasDontEnumBug) {
26         for (var i=0; i < dontEnumsLength; i++) {
27           if (hasOwnProperty.call(obj, dontEnums[i])) result.push(dontEnums[i]);
28         }
29       }
30       return result;
31     }
32   })()
33 };

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:小而美的 React Form 组件

下一篇:checkbox:click事件触发文本框显示隐藏