Home  >  Article  >  Web Front-end  >  What is the difference between find and filter in es6

What is the difference between find and filter in es6

WBOY
WBOYOriginal
2022-05-05 17:07:023506browse

The difference between find and filter in es6: 1. When searching for qualified content in the array without changing the array, the result returned by the find method is an object, and the result returned by the filter method is an array; 2. If no value satisfies the test function, the find method returns undefined, and the filter method returns an empty array.

What is the difference between find and filter in es6

The operating environment of this tutorial: Windows 10 system, ECMAScript version 6.0, Dell G3 computer.

What is the difference between find and filter in es6

1. Find and filter are both methods that do not change the original array. They both find content that meets the conditions in the array without changing the array. , the difference is that find returns an object, and filter returns an array.

The example is as follows:

const list = [{'name':'1',index:1},{'name':'2'},{'name':'1'}]
let list2 = list.find(i=>i.name==='1') 
let list3 = list.filter(i=>i.name==='1')
console.log(list); [ { name: '1', index: 1 }, { name: '2' }, { name: '1' } ]
console.log(list2); { name: '1', index: 1 }
console.log(list3);[ { name: '1', index: 1 }, { name: '1' } ]

find only finds the first result that meets the conditions. In the example, it directly returns an object instead of an array! , and filter returns all results still as arrays.

Note: find() will not traverse the following elements after finding the first element, so if there are two identical elements in the array, it will only find the first one, and the second one will It won’t be traversed again.

2. In summary, find query efficiency is higher, so if the data in the array is unique, it is best to use find

find()

ES6 find() method returns the value of the first element that passes the test function. If no value satisfies the test function, undefined is returned.

Syntax

Arrow functions used in the following syntax.

find((element) => { /* ... */ } )
find((element, index) => { /* ... */ } )
find((element, index, array) => { /* ... */ } )

filter()

The filter() method creates a new array containing all elements that pass the test function. If no elements satisfy the test function, an empty array is returned.

Grammar

filter((element) => { /* ... */ } )
filter((element, index) => { /* ... */ } )
filter((element, index, array) => { /* ... */ } )

Common points

Higher-order functions: Both functions are higher-order functions.

Difference

1. Return the first element through a test function

find().

filter() returns a new array containing all elements that passed the test function.

2. If no value satisfies the test function

find() returns undefined;

filter() returns an empty array;

[Related recommendations :javascript video tutorialweb front-end

The above is the detailed content of What is the difference between find and filter in es6. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn