我知道在 JavaScript 中,对象兼作哈希,但我一直无法找到内置函数来获取键:
var h = {a:'b', c:'d'};
我想要类似的东西
var k = h.keys() ; // k = ['a', 'c'];
自己编写一个函数来迭代项目并将键添加到我返回的数组中很简单,但是有没有标准的更简洁的方法来做到这一点?
我一直觉得它一定是一个简单的内置函数,我错过了但我找不到它!
我知道在 JavaScript 中,对象兼作哈希,但我一直无法找到内置函数来获取键:
var h = {a:'b', c:'d'};
我想要类似的东西
var k = h.keys() ; // k = ['a', 'c'];
自己编写一个函数来迭代项目并将键添加到我返回的数组中很简单,但是有没有标准的更简洁的方法来做到这一点?
我一直觉得它一定是一个简单的内置函数,我错过了但我找不到它!
现代 JavaScript (ECMAScript 5) 中有一个函数称为Object.keys
执行此操作:
var obj = { "a" : 1, "b" : 2, "c" : 3};
alert(Object.keys(obj)); // will output ["a", "b", "c"]
可在此处找到兼容性详细信息。
在Mozilla 站点上还有一个向后兼容的片段:
if(!Object.keys) Object.keys = function(o){
if (o !== Object(o))
throw new TypeError('Object.keys called on non-object');
var ret=[],p;
for(p in o) if(Object.prototype.hasOwnProperty.call(o,p)) ret.push(p);
return ret;
}
对于需要与客户端浏览器有很大兼容性的生产代码,我仍然建议Ivan Nevostruev使用 shim回答以确保Object.keys
在旧浏览器中。但是,使用 ECMA 的新defineProperty
功能可以获得所需的确切功能。
从 ECMAScript 5 开始 - Object.defineProperty
从 ECMA5 开始,您可以Object.defineProperty()
用来定义不可枚举的属性。在目前的兼容性仍然有许多不足之处,但是这应该最终成为所有的浏览器使用。(特别注意当前与IE8不兼容!)
Object.defineProperty(Object.prototype, 'keys', {
value: function keys() {
var keys = [];
for(var i in this) if (this.hasOwnProperty(i)) {
keys.push(i);
}
return keys;
},
enumerable: false
});
var o = {
'a': 1,
'b': 2
}
for (var k in o) {
console.log(k, o[k])
}
console.log(o.keys())
# OUTPUT
# > a 1
# > b 2
# > ["a", "b"]
但是,由于 ECMA5 已经添加,Object.keys
您不妨使用:
Object.defineProperty(Object.prototype, 'keys', {
value: function keys() {
return Object.keys(this);
},
enumerable: false
});
原答案
Object.prototype.keys = function ()
{
var keys = [];
for(var i in this) if (this.hasOwnProperty(i))
{
keys.push(i);
}
return keys;
}
编辑:由于这个答案已经存在了一段时间,我将保持上述不变。任何阅读本文的人还应该阅读下面 Ivan Nevostruev 的回答。
没有办法使原型函数不可枚举,这导致它们总是出现在不使用hasOwnProperty
. 如果扩展 Object 的原型不那么混乱,我仍然认为这个答案是理想的。
您可以使用Object.keys
:
Object.keys(h)
您可以使用Underscore.js,它是一个 JavaScript 实用程序库。
_.keys({one : 1, two : 2, three : 3});
// => ["one", "two", "three"]
据我所知,这是你能做的最好的事情......
var keys = [];
for (var k in h)keys.push(k);