我想获得一个JavaScript对象的键作为一个数组,无论是在jQuery或纯JavaScript。

还有比这更简洁的方法吗?

var foo = { 'alpha' : 'puffin', 'beta' : 'beagle' };
var keys = [];
for (var key in foo) {
    keys.push(key);
}

当前回答

如果你在这里找一些东西来列出一个n深度嵌套对象的键作为一个平面数组:

const getObjectKeys = (obj, prefix = '') => { return Object.entries(obj).reduce((collector, [key, val]) => { const newKeys = [ ...collector, prefix ? `${prefix}.${key}` : key ] if (Object.prototype.toString.call(val) === '[object Object]') { const newPrefix = prefix ? `${prefix}.${key}` : key const otherKeys = getObjectKeys(val, newPrefix) return [ ...newKeys, ...otherKeys ] } return newKeys }, []) } console.log(getObjectKeys({a: 1, b: 2, c: { d: 3, e: { f: 4 }}}))

其他回答

如果你在这里找一些东西来列出一个n深度嵌套对象的键作为一个平面数组:

const getObjectKeys = (obj, prefix = '') => { return Object.entries(obj).reduce((collector, [key, val]) => { const newKeys = [ ...collector, prefix ? `${prefix}.${key}` : key ] if (Object.prototype.toString.call(val) === '[object Object]') { const newPrefix = prefix ? `${prefix}.${key}` : key const otherKeys = getObjectKeys(val, newPrefix) return [ ...newKeys, ...otherKeys ] } return newKeys }, []) } console.log(getObjectKeys({a: 1, b: 2, c: { d: 3, e: { f: 4 }}}))

2022年,JavaScript还没有一个合理的方法来处理哈希?

这将发出警告,但有效:

Object.prototype.keys = function() { return Object.keys(this) }
console.log("Keys of an object: ", { a:1, b:2 }.keys() )

// Keys of an object:  Array [ "a", "b" ]
// WARN: Line 8:1:  Object prototype is read only, properties should not be added  no-extend-native

也就是说,扩展内置对象是有争议的。

当然,Object.keys()是获取对象键的最佳方法。如果它在您的环境中不可用,则可以使用您的示例中的代码简单地填充它(除非您需要考虑到您的循环将遍历原型链上的所有属性,而不像Object.keys()的行为)。

然而,你的示例代码…

var foo = { 'alpha' : 'puffin', 'beta' : 'beagle' };
var keys = [];
for (var key in foo) {
    keys.push(key);
}

jsFiddle。

...可以被修改。你可以在变量部分做赋值。

var foo = { 'alpha' : 'puffin', 'beta' : 'beagle' };
var keys = [], i = 0;
for (keys[i++] in foo) {}

jsFiddle。

当然,这种行为不同于Object.keys()的实际行为(jsFiddle)。您可以简单地使用MDN文档中的填充。

你可以使用jQuery的$.map。

var foo = { 'alpha' : 'puffin', 'beta' : 'beagle' },
keys = $.map(foo, function(v, i){
  return i;
});

用种:

Var foo = { “α”:“雀”, “β”:“小猎犬” }; var keys = Object.keys(foo); Console.log (keys) // ['alpha', 'beta'] //(或者其他顺序,键是无序的)。

这是ES5的一个特性。这意味着它可以在所有现代浏览器中工作,但不能在传统浏览器中工作。

ES5-shim有一个Object的实现。可以偷的钥匙