我有一个JavaScript对象
var obj = {
key1: 'value1',
key2: 'value2',
key3: 'value3',
key4: 'value4'
}
我怎么能得到这个对象中的键的长度和列表?
我有一个JavaScript对象
var obj = {
key1: 'value1',
key2: 'value2',
key3: 'value3',
key4: 'value4'
}
我怎么能得到这个对象中的键的长度和列表?
当前回答
Anurags的回答基本上是正确的。 但是为了在旧的浏览器中也支持Object.keys(obj),你可以使用下面的代码 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/keys . 如果浏览器中没有Object.keys(obj)方法,它会添加该方法。
if (!Object.keys) {
Object.keys = (function() {
'use strict';
var hasOwnProperty = Object.prototype.hasOwnProperty,
hasDontEnumBug = !({ toString: null }).propertyIsEnumerable('toString'),
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 = [], prop, i;
for (prop in obj) {
if (hasOwnProperty.call(obj, prop)) {
result.push(prop);
}
}
if (hasDontEnumBug) {
for (i = 0; i < dontEnumsLength; i++) {
if (hasOwnProperty.call(obj, dontEnums[i])) {
result.push(dontEnums[i]);
}
}
}
return result;
};
}());
}
其他回答
如果你只想要特定于特定对象的键,而不是任何派生的原型属性:
function getKeys(obj) {
var r = []
for (var k in obj) {
if (!obj.hasOwnProperty(k))
continue
r.push(k)
}
return r
}
e.g:
var keys = getKeys({'eggs': null, 'spam': true})
var length = keys.length // access the `length` property as usual for arrays
Var obj = { key1:“value1”, key2: value2, key3:“value3”, key4:“value4” } var keys = Object.keys(obj); Console.log ('obj包含' +键。长度+ '键:'+键);
现在大多数主流浏览器都支持它。
下面是从嵌套对象/数组中获取所有键的解决方案。
它将递归地检查数组中的对象。
function Keys() { let keys = []; this.pushKey = function (key) { keys.push(key); }; this.getKeys = function () { return keys; }; } let keys = new Keys(); let arr = [ { a: 1, b: { c: [{ d: 1, e: [{ f: 1 }] }], }, }, { g: 1, h: { i: [{ j: 1, k: [{ l: 1 }] }], }, }, ]; function getObject(arr) { for (let item of arr) { if (Array.isArray(item)) getObject(item); else getKeys(item); } } function getKeys(obj) { for (let key in obj) { if (Array.isArray(obj[key])) getObject(obj[key]); else if (typeof obj[key] === "object") getKeys(obj[key]); keys.pushKey(key); } } getObject(arr); console.log(keys.getKeys());
if(props.userType){
var data = []
Object.keys(props.userType).map(i=>{
data.push(props.userType[i])
})
setService(data)
}
使用种()……这是正确的方法。
完整的文档可以在MDN网站上找到,链接如下:
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/keys