나는 JavaScript 객체를 가지고있다.
var obj = {
key1: 'value1',
key2: 'value2',
key3: 'value3',
key4: 'value4'
}
이 객체의 길이와 키 목록을 어떻게 얻을 수 있습니까?
나는 JavaScript 객체를 가지고있다.
var obj = {
key1: 'value1',
key2: 'value2',
key3: 'value3',
key4: 'value4'
}
이 객체의 길이와 키 목록을 어떻게 얻을 수 있습니까?
답변:
var obj = {
key1: 'value1',
key2: 'value2',
key3: 'value3',
key4: 'value4'
};
var keys = [];
for (var k in obj) keys.push(k);
alert("total " + keys.length + " keys: " + keys);
Object.prototype
하며 어쨌든 수행해서는 안됩니다. 그러나 커스텀 생성자에게는 맞습니다.
[]
그것에 할당 (또는 array()
그때)하면 배열로 만들어 안전하게 배열로 사용할 수 있습니다.
var obj = {
key1: 'value1',
key2: 'value2',
key3: 'value3',
key4: 'value4'
}
var keys = Object.keys(obj);
console.log('obj contains ' + keys.length + ' keys: '+ keys);
현재 대부분의 주요 브라우저 에서 지원 됩니다.
for(key in ob)
! 와 다릅니다 . Object.keys
프로토 타입의 키는 나열 .. in obj
하지 않지만 그렇지 않습니다.
Underscore.js는 변환을 매우 깨끗하게 만듭니다.
var keys = _.map(x, function(v, k) { return k; });
편집 : 나는 당신도 이것을 할 수있는 것을 놓쳤다.
var keys = _.keys(x);
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;
};
}());
}
사용하십시오 Object.keys()
...가는 길입니다.
전체 문서는 아래 링크 된 MDN 사이트에서 구할 수 있습니다.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/keys
Underscore.js를 사용하기로 결정한 경우 더 잘 수행하십시오.
var obj = {
key1: 'value1',
key2: 'value2',
key3: 'value3',
key4: 'value4'
}
var keys = [];
_.each( obj, function( val, key ) {
keys.push(key);
});
console.log(keys.lenth, keys);
JavaScript에서 객체는 속성과 유형을 가진 독립형 엔터티입니다.
배열 형태로 Object에서 값을 가져 오는 경우 : Object .values (obj) // obj는 사용한 결과 이름 -> [ "value1", "value2", "value3", "value4"]
배열 형식으로 Object에서 키를 가져 오는 경우 : Object .keys (obj) // obj는 사용한 결과 이름 -> [ "key1", "key2", "key3", "key4"]
두 함수 모두 배열을 반환하므로 length 속성을 사용하여 키 또는 값의 길이를 얻을 수 있습니다. 예를 들어 - 개체 .values (OBJ) .length 또는 개체 .keys (OBJ) .length
if(props.userType){
var data = []
Object.keys(props.userType).map(i=>{
data.push(props.userType[i])
})
setService(data)
}
슬라이스, 적용 및 결합 방법을 사용합니다.
var print = Array.prototype.slice.apply( obj );
alert('length='+print.length+' list'+print.join());