[javascript] JavaScript를 사용하여 객체에 값이 있는지 확인하는 방법

JavaScript에 개체가 있습니다.

var obj = {
   "a": "test1",
   "b": "test2"
}

test1이 객체에 값으로 존재하는지 어떻게 확인합니까?



답변

Object의 값을 배열로 바꾸고 문자열이 있는지 테스트 할 수 있습니다. Object가 중첩되지 않고 문자열이 정확히 일치한다고 가정합니다.

var obj = { a: 'test1', b: 'test2' };
if (Object.values(obj).indexOf('test1') > -1) {
   console.log('has test1');
}

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/values


답변

Array 메서드를 사용할 수 있습니다 .some.

var exists = Object.keys(obj).some(function(k) {
    return obj[k] === "test1";
});


답변

시험:

var obj = {
   "a": "test1",
   "b": "test2"
};

Object.keys(obj).forEach(function(key) {
  if (obj[key] == 'test1') {
    alert('exists');
  }
});

또는

var obj = {
   "a": "test1",
   "b": "test2"
};

var found = Object.keys(obj).filter(function(key) {
  return obj[key] === 'test1';
});

if (found.length) {
   alert('exists');
}

이 작동하지 않습니다 NaN-0그 값. ===ECMAScript 6의 새로운 기능 (대신 )을 사용할 수 있습니다 .

 Object.is(obj[key], value);

최신 브라우저에서는 다음을 사용할 수도 있습니다.

var obj = {
   "a": "test1",
   "b": "test2"
};

if (Object.values(obj).includes('test1')) {
  alert('exists');
}


답변

for...in루프 사용 :

for (let k in obj) {
    if (obj[k] === "test1") {
        return true;
    }
}


답변

가장 짧은 ES6 + 1 개 라이너 :

let exists = Object.values(obj).includes("test1");


답변

Object.values ​​() 사용할 수 있습니다 .

Object.values()메서드는 for...in루프에서 제공하는 것과 동일한 순서로 주어진 객체의 고유 한 열거 가능한 속성 값의 배열을 반환합니다
(차이점은 for-in 루프가 프로토 타입 체인의 속성도 열거한다는 것입니다).

그런 다음 indexOf () 메서드 를 사용합니다 .

indexOf()메서드는 배열에서 주어진 요소를 찾을 수있는 첫 번째 인덱스를 반환하거나없는 경우 -1을 반환합니다.

예를 들면 :

Object.values(obj).indexOf("test`") >= 0

더 자세한 예는 다음과 같습니다.

var obj = {
  "a": "test1",
  "b": "test2"
}


console.log(Object.values(obj).indexOf("test1")); // 0
console.log(Object.values(obj).indexOf("test2")); // 1

console.log(Object.values(obj).indexOf("test1") >= 0); // true
console.log(Object.values(obj).indexOf("test2") >= 0); // true 

console.log(Object.values(obj).indexOf("test10")); // -1
console.log(Object.values(obj).indexOf("test10") >= 0); // false


답변

이 모든 예제로 테스트를했고 Node.js v8.11.2 에서 실행했습니다 . 이것을 가이드로 삼아 최선의 선택을 선택하십시오.

let i, tt;
    const obj = { a: 'test1', b: 'test2', c: 'test3', d: 'test4', e: 'test5', f: 'test6' };

console.time("test1")
i = 0;
for( ; i<1000000; i=i+1) {
  if (Object.values(obj).indexOf('test4') > -1) {
    tt = true;
  }
}
console.timeEnd("test1")

console.time("test1.1")
i = 0;
for( ; i<1000000 ; i=i+1) {
  if (~Object.values(obj).indexOf('test4')) {
    tt = true;
  }
}
console.timeEnd("test1.1")

console.time("test2")
i = 0;
for( ; i<1000000; i=i+1) {
  if (Object.values(obj).includes('test4')) {
    tt = true;
  }
}
console.timeEnd("test2")


console.time("test3")
i = 0;
for( ; i<1000000 ; i=i+1) {
  for(const item in obj) {
    if(obj[item] == 'test4') {
      tt = true;
      break;
    }
  }
}
console.timeEnd("test3")

console.time("test3.1")
i = 0;
for( ; i<1000000; i=i+1) {
  for(const [item, value] in obj) {
    if(value == 'test4') {
      tt = true;
      break;
    }
  }
}
console.timeEnd("test3.1")


console.time("test4")
i = 0;
for( ; i<1000000; i=i+1) {
  tt = Object.values(obj).some((val, val2) => {
    return val == "test4"
  });
}
console.timeEnd("test4")

console.time("test5")
i = 0;
for( ; i<1000000; i=i+1) {
  const arr = Object.keys(obj);
  const len = arr.length;
  let i2 = 0;
  for( ; i2<len ; i2=i2+1) {
    if(obj[arr[i2]] == "test4") {
      tt = true;
      break;
    }
  }
}
console.timeEnd("test5")

내 서버에 출력

test1:   272.325 ms
test1.1: 246.316 ms
test2:   251.98 0ms
test3:    73.284 ms
test3.1: 102.029 ms
test4:   339.299 ms
test5:    85.527 ms