Javascript에는 많은 내장 함수가 있는데, filter()가 그 중 하나입니다. 그 기능은 배열에서 기준을 충족하는 요소를 필터링하고 새 배열을 반환하는 것입니다.
filter() 구문은 다음과 같습니다.
array.filter(function(currentValue, index, arr), thisValue)
매개변수 설명:
filter() 메서드는 함수를 매개 변수로 허용하며, 이는 현재 요소의 세 가지 매개 변수를 허용합니다. , 현재 요소 및 전체 배열의 인덱스입니다. 함수는 현재 요소가 조건을 충족하는지 여부를 나타내는 부울 값을 반환해야 합니다. true가 반환되면 해당 요소는 새 배열에 유지되고, 그렇지 않으면 필터링됩니다.
1부터 10까지의 정수를 저장하는 배열이 있다고 가정하고 예를 들어보겠습니다.
const numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
이제 5보다 크거나 같은 모든 요소를 필터링하려고 합니다. 이는 filter() 메서드를 통해 달성할 수 있습니다.
const result = numbers.filter(function(number) { return number >= 5; }); console.log(result); // 输出 [5, 6, 7, 8, 9, 10]
위 코드에서 filter() 함수는 반환 값이 true 또는 false인 함수를 받습니다. 이 함수에서는 현재 요소가 5보다 크거나 같으면 true가 반환됩니다. 그렇지 않고 현재 요소가 5보다 작으면 false가 반환됩니다. 마지막으로 기준을 충족하는 요소, 즉 5보다 크거나 같은 요소는 그대로 유지되어 새로운 배열 형태로 반환됩니다.
함수를 정의하는 것 외에도 화살표 함수를 간략하게 사용할 수도 있습니다.
const result = numbers.filter(number => number >= 5); console.log(result); // 输出 [5, 6, 7, 8, 9, 10]
filter() 메서드는 배열의 객체에 사용할 수도 있습니다. 여러 사람에 대한 정보를 저장하는 배열이 있다고 가정해 보겠습니다.
const people = [ { name: 'Lucas', age: 25 }, { name: 'Emma', age: 21 }, { name: 'Tom', age: 30 }, { name: 'Jane', age: 18 }, ];
이제 25세 이상의 사람들을 필터링하고 싶습니다. 이는 filter() 메서드를 통해 달성할 수 있습니다:
const result = people.filter(function(person) { return person.age >= 25; }); console.log(result); // 输出 [{ name: 'Lucas', age: 25 }, { name: 'Tom', age: 30 }]
마찬가지로 화살표 함수 약어를 사용할 수도 있습니다:
const result = people.filter(person => person.age >= 25); console.log(result); // 输出 [{ name: 'Lucas', age: 25 }, { name: 'Tom', age: 30 }]
실제 개발에서는 검색과 같은 조건을 충족하는 데이터를 필터링하는 데 filter() 메서드가 자주 사용됩니다. , 필터링, 분류 등을 현장에서 수행합니다. 간단하고 사용하기 쉬우며, 배열 요소를 빠르게 필터링할 수 있는 것은 개발에 없어서는 안 될 방법 중 하나라고 할 수 있습니다.
위 내용은 자바스크립트 필터 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!