JavaScript에서 여러 조건을 기반으로 개체 배열을 필터링하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-10-26 03:09:27
원래의
705명이 탐색했습니다.

How to Filter an Array of Objects Based on Multiple Conditions in JavaScript?

JavaScript에서 여러 조건을 기반으로 객체 배열 필터링

문제:

객체 배열과 필터가 제공됨 객체에서 우리는 필터 객체에 지정된 여러 조건을 기반으로 배열 요소를 필터링하는 것을 목표로 합니다. 그러나 현재 구현에서는 조건의 하위 집합만 충족하는 여러 요소가 결과에 포함되는 문제가 발생합니다.

해결책:

문제는 잘못된 사용으로 인해 발생합니다. 필터링 함수 내의 for (var i = 0; i < filter.length; i ) 루프. 필터는 객체이므로 길이 속성이 없으며 이 루프는 중복됩니다.

이 문제를 해결하려면 필터 객체의 속성을 직접 반복하고 각 사용자 객체의 속성 존재를 확인할 수 있습니다. . 다음 코드는 올바른 구현을 보여줍니다.

<code class="javascript">function filterUsers(users, filter) {
  var result = [];
  for (var prop in filter) {
    if (filter.hasOwnProperty(prop)) {
      users.forEach(function(user) {
        if (user[prop] === filter[prop]) {
          result.push(user);
        }
      });
    }
  }
  return result;
}</code>
로그인 후 복사

향상된 필터 함수:

향상된 filterUsers 함수는 이제 사용자를 반복하고 필터 개체의 각 속성을 확인합니다. 사용자의 해당 속성 값과 일치하는지 확인합니다. 지정된 모든 속성에 대해 일치하는 값을 가진 사용자만 결과에 포함됩니다.

예:

<code class="javascript">var filter = {
  address: 'England',
  name: 'Mark',
};
var users = [{
  name: 'John',
  email: 'john@example.com',
  age: 25,
  address: 'USA',
},
{
  name: 'Tom',
  email: 'tom@example.com',
  age: 35,
  address: 'England',
},
{
  name: 'Mark',
  email: 'mark@example.com',
  age: 28,
  address: 'England',
},
];

var filteredUsers = filterUsers(users, filter);

console.log(filteredUsers);
// Output: [{
//   name: 'Mark',
//   email: 'mark@example.com',
//   age: 28,
//   address: 'England',
// }]</code>
로그인 후 복사

이 구현은 이름이 Mark이고 필터 조건에 지정된 대로 영국에 거주하는 사람이 결과에 포함됩니다.

위 내용은 JavaScript에서 여러 조건을 기반으로 개체 배열을 필터링하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!